2020-11-22:mysql中,什么是filesort?

举报
福大大架构师每日一题 发表于 2020/11/22 20:39:35 2020/11/22
【摘要】 福哥答案2020-11-22:[答案来自此链接:](http://bbs.xiangxueketang.cn/question/412)如果mysql在排序的时候没有使用到索引那么就会输出 using filesort。filesort有两种实现1.一遍扫描一遍扫描数据后将select需要的列数据以及排序的列数据都取出来,这样就不需要进行第二遍扫描了。2.两遍扫描第一遍扫描出需要排序的字段,...

福哥答案2020-11-22:

[答案来自此链接:](http://bbs.xiangxueketang.cn/question/412)

如果mysql在排序的时候没有使用到索引那么就会输出 using filesort。

filesort有两种实现

1.一遍扫描

一遍扫描数据后将select需要的列数据以及排序的列数据都取出来,这样就不需要进行第二遍扫描了。

2.两遍扫描

第一遍扫描出需要排序的字段,然后进行排序后,根据排序结果,第二遍再扫描一下需要select的列数据。


具体采用哪种扫描是根据max_length_for_sort_data来判断的。

如果需要的列数据一行可以放入max_length_for_sort_data则使用一遍扫描否则使用两遍扫描。

***

[评论](https://user.qzone.qq.com/3182319461/blog/1606001023)


【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。