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,让查询尽量走双路排序,避免使用磁盘文件排序
相关推荐
Meepo_haha几秒前
python的sql解析库-sqlparse
数据库·python·sql
岁岁种桃花儿3 分钟前
AI超级智能开发系列从入门到上天第六篇:自定义AI记忆持久化
数据库
黄昏回响4 分钟前
计算机系统基础知识(补充篇):数据库——数据仓库、数据中台与大数据技术详解
大数据·数据库·数据仓库
sqyno1sky7 分钟前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
总有刁民想爱朕ha11 分钟前
数据库行统计和字典导出工具Web版
前端·数据库
知识分享小能手19 分钟前
MongoDB入门学习教程,从入门到精通,MongoDB 知识点详解(1)
数据库·学习·mongodb
Seven9720 分钟前
揭秘MySQL索引分类
mysql
njidf22 分钟前
使用Python分析你的Spotify听歌数据
jvm·数据库·python
2301_7938046925 分钟前
数据分析与科学计算
jvm·数据库·python
常利兵27 分钟前
Java后端定时任务抉择:@Scheduled、Quartz、XXL - Job终极对决
java·数据库·sql