MySQL排序详解

  • 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,让查询尽量走双路排序,避免使用磁盘文件排序
相关推荐
喝醉酒的小白33 分钟前
MySQL响应慢是否由堵塞或死锁引起?
数据库
Pasregret36 分钟前
04-深入解析 Spring 事务管理原理及源码
java·数据库·后端·spring·oracle
jnrjian42 分钟前
归档重做日志archived log (明显) 比redo log重做日志文件小
数据库·oracle
TDengine (老段)1 小时前
TDengine 中的命名与边界
大数据·数据库·物联网·oracle·时序数据库·tdengine·iotdb
谁家有个大人2 小时前
MYSQL中对行与列的操作
数据库·mysql
0000ysl2 小时前
数据库基础-函数&约束
数据库
JavaPub-rodert3 小时前
Etcd用的是Raft算法
数据库·github·etcd·raft
编程乐趣3 小时前
FlexLabs.Upsert:EF Core插件推荐,支持多数据库的Upsert功能
数据库
dogplays3 小时前
dbeaver无法连接Oracle报错:ORA-17800、ORA-12514
数据库·oracle
Acrelhuang3 小时前
8.3MW屋顶光伏+光储协同:上海汽车变速器低碳工厂的能源革命-安科瑞黄安南
大数据·数据库·人工智能·物联网·数据库开发