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,让查询尽量走双路排序,避免使用磁盘文件排序
相关推荐
老华带你飞18 分钟前
音乐网站|基于SprinBoot+vue的音乐网站(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·音乐网站
gadiaola5 小时前
MySQL从入门到精通(三):MySQL数据类型、SQL语言—DDL
数据库·sql·mysql·database
muxue1786 小时前
关于almalinux分区配置:
linux·运维·数据库
海天胜景7 小时前
Asp.Net Core IIS发布后PUT、DELETE请求错误405
数据库·后端·asp.net
凯子坚持 c7 小时前
【金仓数据库征文】金仓数据库 KES:MySQL 迁移实用指南
数据库·金仓数据库 2025 征文·数据库平替用金仓
小刘|8 小时前
Redis 中简单动态字符串(SDS)的深入解析
数据库·redis·bootstrap
怀君9 小时前
Flutter——数据库Drift开发详细教程(四)
数据库·flutter
万能程序员-传康Kk9 小时前
中国邮政物流管理系统(Django+mysql)
python·mysql·django
pqq的迷弟9 小时前
Redis的过期设置和策略
数据库·redis
JhonKI9 小时前
【MySQL】存储引擎 - CSV详解
android·数据库·mysql