Indexing your database fields – when and why.
This is fairly straightforward. Indexing improves the performance of your database when doing certain things in your queries, including ORDER BY, WHERE and JOIN….among others I’m sure.
Indexing fields allows your database to reference a, well, index. Think of it literally as the index at the back of a book. It’s order alphabetically, and your given a page number. The very same logic applies to the database.
Whenever you are going to ORDER by a field or any sort of lookup against a field, i.e WHERE my_field = 1; you want it indexed. Your database will then refer to the indexes, find the rows it needs, in the correct order if necessary and in turn, returns the content for those rows. Without indexing every row of data is checked every time, just like flicking through an entire book to find 1 paragraph.
There is caching available in some database languages, however you should not be relying on it, when a simple index is worth far more.
Different types of index
Primary, Unique, Index & Full-text. For some databases, or even installations of MySQL, there are others available ie Spatial.
Each type has a different use.
- Primary, most often this is an auto-incrementing id.
- Unique, as it states data you require to be unique, username for example
- Index, not required to be unique but you add for performance, something like the date a user signed up for displaying the latest user on your site. A Django example is available on djangorocks.com
- Full-text, allows full-text searching of text fields
- Spatial, used for geometry based data to be stored and compared. Depending on the database this is only 1 of many indexing types.