手机版
你好,游客 登录 注册 搜索
背景:
阅读新闻

MySQL优化-using filesort

[日期:2013-07-10] 来源:Linux社区  作者:smart818 [字体: ]

MySQL 中 filesort的实现算法实际上是有两种的,一种是首先根据相应的条件取出相应的排序字段和可以直接定位行数据的行指针信息,然后在 sort buffer中进行排序。另外一种是一次性取出满足条件行的所有字段,然后在 sort buffer 中进行排序。

在MySQL4.1版本之前只有第一种排序算法,第二种算法是从 MySQL4.1开始的改进算法,主要目的是为了减少第一次算法中需要两次访问表数据的 IO操作,将两次变成了一次,但相应也会耗用更多的 sort buffer空间。当然,MySQL4.1开始的以后所有版本同时也支持第一种算法,MySQL 主要通过比较我们所设定的系统参数max_length_for_sort_data 的大小和 Query 语句所取出的字段类型大小总和来判定需要使用哪一种排序算法。如果max_length_for_sort_data 更大,则使用第二种优化后的算法,反之使用第一种算法。所以如果希望 ORDER BY操作的效率尽可能的高,一定要注意max_length_for_sort_data 参数的设置。

相关阅读:

MySQL优化案例分析 http://www.linuxidc.com/Linux/2007-01/2242.htm

MySQL优化:可配置选项的WAIT_FOR_READ http://www.linuxidc.com/Linux/2012-03/57204.htm

CentOS系统MySQL优化详解 http://www.linuxidc.com/Linux/2011-09/42426.htm

linux
相关资讯       MySQL优化 
本文评论   查看全部评论 (0)
表情: 表情 姓名: 字数

       

评论声明
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款