Mysql中use filesort的误区

2019-07-24 09:03:34来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

误区一字面误区

use filesort排序,字面上理解是外部排序。

误区二人云亦云

百度上多被大家否定不是外部排序,认为和file这个关键字没关系。用的是快速排序。但是总觉得不可能这么无缘无故叫filesort的,于是去官网查了下。

正解

官方解释

果然,大家认为的只有一半,正解是上面两种都有,use filesort会在内存中排序,但是如果结果集过大不能使用内存就会使用外部排序。(无论filesort底层用的哪种排序都是额外的排序,只不过内存排序比外部排序快一点,都需要优化sql啦~这里只探究filesort原理

验证

下载mysql源码

直接访问github地址https://github.com/mysql/mysql-server/进行下载或直接查看

也可以去官网下载,和下载mysql包一样,不赘述,只需要在最后一步中Select Operating System选择Source Code

查看源码

抛砖引玉~由各位大佬分析一波~~~(悄悄的告诉你们,我压根就找不到排序的c文件在哪...)

~~~~~~

原创,转载请注明来源,翻版必究


原文链接:https://www.cnblogs.com/aeolian/p/11199648.html
如有疑问请与原作者联系

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:如何把转入成功的XXX.sql导入到自己的数据库里

下一篇:Yii basic 模板支持连接多数据库