MySQL排序优化

排序优化

对于order by关键字进行优化前,首先大家要先知道索引不仅用于检索还用于排序

MySQL支持两种方式的排序,index和filesort,index效率高,可以根据索引本身来完成排序,filesort效率较低

最好在进行explain进行分析时不要出现filesort

使用index

通过有序索引而直接取得有序的数据,这样就可以不需要进行任何排序操作即可满足客户端要求的有序数据

  • order by 语句使用索引最左前列
  • 使用where 子句和order by子句组合满足索引最左前列

如果使用多字段排序,需要保证排序方向一致,要么就全是ASC要么就全是DESC

sql 复制代码
show status like 'sort%';
-- Sort_merge_passes	0
-- Sort_range	1
-- Sort_rows	2
-- Sort_scan	0

使用filesort

在使用explain时如果发现在Extra信息中出现Using filesort,表示使用了filesort排序

需用通过Mysql的排序算法将存储引擎中返回的数据进行排序,然后再将排序后的数据返回给客户端

如果逼不得已使用filesort,MySQL中filesort有两种算法,双路排序和单路排序

双路排序(两次传输排序)

4.1之前使用的是双路排序,即需要扫描两次磁盘,读取行指针和order by列,对他们进行排序,然后扫描已经排好序的列表,按照列表中的值重新从列表中读取对应的数据输出(回表),第二次读取数据的时候,是读取的排序后的所有记录,会产生大量的随机IO

取出满足过滤条件的用于排序条件的字段以及可以直接定位到行数据的行指针信息,在Sort Buffer中进行实际的排序操作,然后利用排好序之后的数据根据指针信息返回表中取得客户端请求的其他字段的数据

此时在trace中看到的信息是 <sort_key,rowid>

单路排序(单次传输排序)

4.1之后出现单路排序,从磁盘中查询所有列,按照order by列在buffer进行排序,然后扫描排序后的列表进行输出,减少了数据的二次访问,节省了IO操作

根据过滤条件一次取出排序字段以及客户端请求的所有其他字段的数据,并将不需要排序的字段存放在一块内存区域中,然后在sort Buffer中将排序字段和行指针信息进行排序,最后再利用排序后的行指针与存放在内存区域中的其他字段一起的行指针信息进行匹配合并结果集

但是如果需要返回的列非常多,会占用大量的空间

此时在trace中看到的信息是<sort_key,additional_fields>或<sort_key,packedadditional_fields>

两个重要的配置

  • sort_buffer_size : 该配置是配置的sort buffer的大小,增大该配置,可以尽量减少在排序过程中对需要排序的数据进行分段,如果进行分段会导致MySQL不得不使用临时表来进行数据交换
  • max_length_for_sort_data: 当query的字段大小总和小于max_length_for_sort_data且字段中不包含text或者blob类型时,会使用单路排序

禁忌

有时候需要排序的字段同时存在于两个表,或者在经过一次join之后才进行排序,此时仅使用sort Buffer已经不能满足要求了,需要使用临时表来将之前join的结果集存放在临时表中,再将临时表的数据提取到sort Buffer中进行操作,此时性能可就很差了,使用explain执行计划可以看到extra字段中为using temporary和using filesort

zhhll.icu/2021/数据库/关系...

本文由mdnice多平台发布

相关推荐
青云交15 分钟前
大数据新视界 -- Hive 数据分区:提升查询效率的关键步骤(下)(8/ 30)
大数据·数据库·精细化管理·hive 数据分区·分区修剪·分区合并·缓存协同
重生之我是数学王子19 分钟前
QT简易项目 数据库可视化界面 数据库编程SQLITE QT5.12.3环境 C++实现
数据库·c++·qt
sevevty-seven25 分钟前
详细讲解MySQL中的默认索引(B+树)
数据库·b树·mysql
蓝天扶光31 分钟前
MySQL事务知识点梳理
数据库·mysql
Kika写代码44 分钟前
【大数据技术基础】 课程 第5章 HBase的安装和基础编程 大数据基础编程、实验和案例教程(第2版)
大数据·数据库·hbase
摸鱼小天才1 小时前
浅析REGEXP_SUBSTR,PRIOR,CONNECT BY
数据库
蓝晶之心1 小时前
JAVA之若依框架——达梦数据库
java·开发语言·数据库
冧轩在努力1 小时前
【redis 】string类型详解
数据库·redis·缓存
bigbig猩猩1 小时前
C/C++链接数据库(MySQL)超级详细指南
c语言·数据库·c++
枫林残忆1681 小时前
第02章_MySQL环境搭建(基础)
数据库·mysql