order by排序--filesort调优

场景:order by排序时出现临时文件排序,一般是数据没有走索引,或者设置了索引但是索引顺序不一致。

当你用explain命令对查询语句进行分析时,往往遇到rder by排序时会出现using filesort。这个时候如果想要继续查看详细的执行过程,需要借助optimizer trace(优化器追踪),MySQL5.6版本之后开始引入的。

. 使用optimizer trace查看优化器的选择过程,重点关注"filesort_summary":{}里面的参数,参数里可以关注num_initial_chunks_spilled_to_disk(产生了多少临时文件,0表示完全基于内存排序)的值。

还可以通过show status  like  '%sort_merge_passes%':进行归并排序的次数。

如果num_initial_chunks_spilled_to_disk和sort_merge_passes的值比较大,这个时候可以适当调整sort_buffer_size的值。让MySQL尽量减少在排序过程中对需要排序的数据进行分段,从而避免使用临时表来进行交换排序。这个值不是越大越好,

  1. sort_buffer_size的默认值在不同的MySQL版本中有所不同。在某些版本中,默认值为256KB(262144字节),而在MySQL 5.7中,默认值为1MB(1048576字节)。

    2.官方文档推荐的范围为256KB到2MB。

可以基于官方文档推荐的范围,结合实际数据量进行调整。 

知识扩展:聊聊 order by

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在MySQL中,GROUP BY是用于将结果集按照指定的列进行分组的操作。当使用GROUP BY时,MySQL会对结果集进行排序,以便将相同值的行放在一起形成分组。 但是,有时候在使用GROUP BY时,会发生filesort的情况。filesort是MySQL在执行排序操作时,需要借助磁盘临时文件进行排序的情况。这种情况可能会出现在以下几种情况下: 1. 数据量过大:如果要进行GROUP BY的列包含大量的数据,并且无法在内存中完成排序,MySQL就会使用文件进行排序操作。 2. 数据类型不同:如果要进行GROUP BY的列包含不同的数据类型,MySQL需要将其转换为相同的数据类型进行比较和排序,这可能会导致filesort的发生。 3. 多表连接:如果GROUP BY操作涉及多个表的连接,MySQL需要先执行连接操作,然后再进行分组和排序,这可能会增加排序的复杂性和数据量,导致filesort的发生。 为了优化GROUP BY操作,可以考虑以下几点: 1. 确保数据库的设计符合规范:合理设计表结构、索引和数据类型,能够提高GROUP BY的性能。 2. 限制结果集的大小:如果可能的话,尽量通过WHERE子句或LIMIT关键字来限制结果集的大小,减少排序的复杂性和数据量。 3. 考虑使用索引:根据具体情况,在GROUP BY列上创建合适的索引,能够加快排序的速度。 4. 分区表:对于较大的数据表,可以考虑将其按照一定的规则划分为多个分区表,这样在进行GROUP BY操作时,可以只操作某个分区,减少排序的数据量。 总之,GROUP BY操作可能导致filesort的发生,但可以通过优化数据库设计、限制结果集的大小、使用索引和分区表等方法,来提高GROUP BY的性能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值