You are not logged in.
I'm trying to create a web application that makes use of a database to track user information. I have some experience using databases, but none in schema design. My question: Is it better to split information up in many tables or to have as much data in a single table as possible?
Use case: Each user has a profile page where they can enter information, post content, etc. so I'm trying to decide whether to have a single table with user name, encrypted password, birth date, and all the profile information (probably a bunch of text blurbs), or whether to split it up into a user information table and a profile information table. Which would be better in terms of performance?
Last edited by Diospyros (2009-06-20 21:25:29)
Offline
the google search keywords you want are 'data normalization'. Basically, try to design your tables so there's no duplicate columns, and no duplicate information between rows. But don't go overboard because too many joins can be expensive.
Dusty
Offline
Generally it's better to use less tables. Unless you have one-to-many relationship I suggest you use one table and leave null if some field is empty.
Offline
If the database is supposed to be a long term solution with many entries, I think you should decently normalize your schema. As said before look into schema normalisation and head for at least a 3NF design, possibly BCNF if that's possible without causing problems.
Offline
Alright thanks everyone!
I found a couple of good resources for basic understanding, links for anyone stumbling on this page later:
http://en.csharp-online.net/Relational_ … malization
http://www.datamodel.org/NormalizationRules.html
Offline