索引优化 :提升排序、GROUP BY与分页性能
1.排序优化
1.1排序优化
问题: 在WHERE
条件字段上加索引但是为什么在ORDER BY
字段上还要加索引呢?
回答:
在MySQL中,支持两种排序方式,分别是FileSort和Index排序。
- Index排序中,索引可以保证数据的有序性,不需要再进行排序,效率更高。
- FileSort排序则一般在内存中进行排序,占用CPU较多。如果待排结果较大,会产生临时文件I/O到磁盘进行排序的情况,效率较低。
优化建议:
- SQL中,可以在
WHERE
子句和ORDER BY
子句中使用索引,目的是在WHERE子句中避免全表扫描,在ORDER BY子句避免使用FileSort排序。当然,某些情况下全表扫描,或者FileSort排序不一定比索引慢。但总的来说,我们还是要避免,以提高查询效率。 - 尽量使用Index完成
ORDER BY
排序。如果WHERE和ORDER BY
后面是相同的列就使用单索引列;如果不同 就使用联合索引。 - 无法使用Index时,需要对FileSort方式进行调优。