I realized, that the response to a MySQL query becomes much faster, when creating an index for the column you use for “ORDER BY”, e.g.
SELECT username FROM table ORDER BY registration_date DESC
Now I’m wondering which indices I should create to optimize the request time.
For example I frequently use the following queries:
SELECT username FROM table WHERE
registration_date > ".(time() - 10000)."
SELECT username FROM table WHERE
registration_date > ".(time() - 10000)."
&& status='active'
SELECT username FROM table WHERE
status='active'
SELECT username FROM table ORDER BY registration_date DESC
SELECT username FROM table WHERE
registration_date > ".(time() - 10000)."
&& status='active'
ORDER BY birth_date DESC
Question 1:
Should I set up separate indices for the first three request types? (i.e. one index for the column “registration_date”, one index for the column “status”, and another column for the combination of both?)
Question 2:
Are different indices independently used for “WHERE” and for “ORDER BY”? Say, I have a combined index for the columns “status” and “registration_date”, and another index only for the column “birth_date”. Should I setup another combined index for the three columns (“status”, “registration_date” and “birth_date”)?
There are no hard-and-fast rules for indices or query optimization. Each case needs to be considered and examined.
Generally speaking, however, you can and should add indices to columns that you frequently sort by or use in WHERE statements. (Answer to Question 2 — No, the same indices are potentially used for
ORDER BYandWHERE) Whether to do a multi-column index or a single-column one depends on the frequency of queries. Also, you should note that single-column indices may be combined by mySQL using the Index Merge Optimization:(more reading: http://dev.mysql.com/doc/refman/5.0/en/index-merge-optimization.html)
Multi-column indices also require that you take care to structure your queries in such a way that your use of indexed columns matches the column order in the index:
Bear in mind that indices DO have a performance consideration of their own — it is possible to “over-index” a table. Each time a record is inserted or an indexed column is modified, the index/indices will have to be rebuilt. This does demand resources, and depending on the size and structure of your table, it may cause a decrease in responsiveness while the index building operations are active.
Use
EXPLAINto find out exactly what is happening in your queries. Analyze, experiment, and don’t over-do it. The shotgun approach is not appropriate for database optimization.Documentation
EXPLAIN– http://dev.mysql.com/doc/refman/5.0/en/explain.html