数据库优化<六>SQL优化之SELECT优化 ——filesort

本文深入解析了MySQL中filesort的工作原理,包括其涉及的快速排序和归并排序步骤,以及如何通过调整参数如sort_buffer_size和max_length_for_sort_data来优化性能。建议包括减小max_length_for_sort_data以利用更高效的方法,增加sort_buffer_size以减少磁盘I/O,以及设置多物理盘的tmpdir以分散临时文件存储。
摘要由CSDN通过智能技术生成

在执行计划中,可能经常看到有Extra列有filesort,这就是使用了文件排序,这当然是不好

的,应该优化,但是,了解一下他排序的原理也许很有帮助,下面看一下filesort的过程:

         1、根据表的索引或者全表扫描,读取所有满足条件的记录

         2、对与每一行,存储一对儿值到缓冲区,一个是排序的索引列的值,即order by用到

               的列值,和执向该行数据的行指针,缓冲区的大小为sort_buffer_size大小

         3、当缓冲区满后,运行一个快速排序(qsort)来将缓冲区中数据排序,并将排序完的

                数据存储到一个临时文件,并 保存一个存储块儿的指针,当然,如果缓冲区不满,

                则不会重建临时文件了

         4、重复以上步骤,直到将所有行读完,并建立相应的有序的临时文件

         5、对块级进行排序,这个类似与归并排序算法,只通过两个临时文件的指针来不断交换

               数据,最终达到两个文件,都是有序的

         6、重复5,直到所有的数据都排序完毕

         7、采取顺序读的方式,将每行数据读入内存,并取出数据传到客户端,这里读取数据时

                并不是一行一行读,读如缓存大小由read_rnd_buffer_size来指定

这就是filesort的过程,采取的方法为:

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值