This question is geared towards MySQL, since that is what I’m using — but I think that it’s probably the same or similar for almost every major database implementation.
How do keys work in a database? By that I mean, when you set a field to ‘primary key’, ‘unique key’ or an ‘index’ — what do each of these do, and when should I use each one?
Right now I have a table containing a few fields, one of them being a GUID (minus the { and } around it). I set the GUID field to the primary key and I see that it created a binary tree. So it improves search performance — but what differentiates that from other types of keys?
I realize this may not really be programming related (although it is development related) — I wasn’t sure where exactly to ask this but SO is what I use the most so I’ll ask here. Migrate as necessary
There are probably hundreds of references for this elsewhere on the web, so a bit of Googling will help you get deep into understanding DB design. That said, the basic gist is: