排序优化

ORDER BY子句,尽量使用Index方式(索引)排序,避免使用FileSort方式(手工)排序。

技巧:无过滤,不索引;顺序错,必手工排序;方向反,必手工排序;

  • 要想Order BY使用到索引,必须要添加过滤条件(where子句对索引中的字段进行过滤,而且必须按照顺序),Limit分页也行。
  • 在SQL语句中的顺序一定要和定义索引中的字段顺序完全一致!
  • 要么全升序、要么全降序。有升有降无法使用索引

案例

SELECT SQL_NO_CACHE * FROM emp WHERE age =30 AND empno <101000 ORDER BY NAME ;

可以看到,上面where条件中有范围查询,那么后面的索引会失效。

那么我们可以创建两个索引,一个是idx_age_empno(避免不了Using filesort),另一个是idx_age_name(不能让where条件充分用到索引),当这两个索引同时存在的时候,MySQL会选择谁作为最优索引呢?会选择让where子句舒服的索引,即idx_age_empno

Using filesort有两种排序算法

一种是单路排序,一种的双路排序。

单路排序更快,因为使用到了内存。

分组优化

Group By 使用索引的原则几乎跟Order By一致 ,唯一区别是Group By即使没有过滤条件用到索引,也可以直接使用索引。

最后修改日期:2020-07-12

作者

留言

撰写回覆或留言

发布留言必须填写的电子邮件地址不会公开。