-
MySQL支持两种方式排序filesort和index
-
index是指扫描索引本身完成排序,index效率高
-
filesort是指通过内存或者排序文件完成排序,filesort效率低
-
order by满足两种情况时会使用index排序
- order by语句使用索引最左列
- where条件字段和order by字段组合满足索引最左列

- sort_buffer_size配置
- 给每个回话分配排序操作的缓冲区大小
- 当需要排序的数据>大于该配置时,MySQL使用磁盘文件排序

- filesort支持两种排序方式单路排序和双路排序
- filesort单路排序:一次行去除满足条件的所有字段,然后进行排序
- filesort双路排序:根据相应的条件取出排序字段和主键id,进行排序,排序完成后根据主键id回表查询其余信息
- max_length_for_sort_data配置
- 当查询单行数据长度小于该配置时使用单路排序
- 大于该配置时使用双路排序

使用mysql trace信息观察排序方式
- 单路排序

- 调整max_length_for_sort_data观察双路排序

- 当sort_buffer_size配置大时,可适当调大max_length_for_sort_data,让查询尽量走单路排序,避免其回表查询
- 当sort_buffer_size配置小时,可适当调小max_length_for_sort_data,让查询尽量走双路排序,避免使用磁盘文件排序