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,让查询尽量走双路排序,避免使用磁盘文件排序
相关推荐
yejqvow121 分钟前
CSS项目样式如何模块化_应用BEM规范构建组件化逻辑
jvm·数据库·python
m0_748920361 分钟前
宝塔面板安装后无法访问宝塔官网接口_检查服务器外网连通性
jvm·数据库·python
qq_342295826 分钟前
如何用 Chrome 的 Rendering 面板监控页面的重排频率
jvm·数据库·python
u0109147607 分钟前
SQL如何高效统计分类下的多项指标_善用CASE WHEN与SUM聚合
jvm·数据库·python
HHHHH1010HHHHH7 分钟前
如何在MongoDB中实现按时间跨度的分片路由_时间序列范围分片与冷热节点架构
jvm·数据库·python
m0_515098429 分钟前
Python测试框架如何处理重载_在pytest中使用mocker控制调用
jvm·数据库·python
yngsqq10 分钟前
运行c#脚本
开发语言·数据库·c#
weixin_3812881810 分钟前
HTML函数在旧版Windows跑得动吗_系统版本与硬件协同影响【指南】
jvm·数据库·python
qq_3300379911 分钟前
HTML怎么显示同步冲突提示_HTML“云端有更新”解决选项【教程】
jvm·数据库·python
2301_8166602111 分钟前
HTML怎么创建多语言切换器_HTML语言选择下拉结构【指南】
jvm·数据库·python