Hudzilla.org - the homepage of Paul Hudson
Contents > Databases Wish List | Report Bug | About Me ]

9.12     How to design your tables

This is NOT the latest copy of this book; click here for the latest version.

Designing unwieldy database tables is remarkably easy to do, as you can clearly see if you go to any company where a non-technical person uses Microsoft Access to store their data. While monolithic, "hack"-style databases are okay, they will not give you the best performance, and certainly will not operate at maximum efficiency.

We have already looked at normalisation, so you should be aware of how to design your tables so that they are dependent on each other for information. However, there are other factors to keep in mind when designing your tables - what to choose as your primary key, what data types to use, what to index and what not to index, etc.

Owing to the variety of database possibilities, large amounts of this information needs to come through experience. However, experience database designers will usually tell you that the best way to get started with a solid design is to treat your table as a thing in real life - to model it around the real-world. For example, if your table needs to store information about members of a club, the absolute easiest way to begin is just to take the fields from the paper membership form and create table fields out of them. Yes, you will need to do more work such as assigning keys, creating indexes, and adding other implementation-specific attributes, but it is a good start.





<< 9.11 Adjusting the priority queue   9.13 Picking the perfect data type >>
Table of Contents
Want to see this stuff in print? PHP in a Nutshell takes the core topics covered here, adds in thousands of edits from the editorial team and myself, and combines them to make an unbeatable reference for PHP programmers at all levels.



My latest book has hundreds more tips on how to use PHP, Apache, and MySQL, plus Perl, Python, shell scripts, performance tuning, and more!



Top-right shadow
 
Bottom-left shadow Bottom shadow

Comments from other readers
Be the first to add a comment to this chapter!



Add comment
Please note that by posting a comment here you are committing it to the public domain. This is important so that others can make use of your code themselves, and also so that I can incorporate helpful notes directly into the main text. Comments are limited to 2000 characters in length.

If you are reporting an error in the content, please tell me directly.

Your name/email address:
Your comment:
 
Now, in order to verify that you're a real person, please answer this simple question: what is seven plus four?
The answer is:
(please write in
numbers, eg 19)


Top-right shadow
 
Bottom-left shadow Bottom shadow