理解mysql_order by排序原理及优化
来源:互联网 发布:linux命令的压缩和解压 编辑:程序博客网 时间:2024/06/12 19:14
一、排序算法
a. 一次扫描性能高,减少了io随机请求的次数
b. 排序操作是在内存(sort_buffer)里面进行的, 先select结果再进行排序,如果结果值大于max_length_for_sort_data 阀值设置需要二次io读取
c. 关联查询会产生临时表再进行order by
二、优化思路
a. 尽量减少io的读取 max_length_for_sort_data 阀值设置
b. 尽量使用有序排序输出。 运用覆盖索引、主键索引
c. 控制select 字段数,不需要的字段没必要输入
d. …….
一次扫描算法(4.1版本以后支持)
1)、根据条件取出所有字段信息
2)、在sort_buffer中进行排序, 如果sort_buffer较小,产生临时表,在临时表存储排序结果
选用一次排序扫描还是二次排序扫描, 需要根据参数来: max_length_for_sort_data
如果取的值 大于 max_length_for_sort_data 设置的值,采用二次扫描。
两个参数:
max_length_for_sort_data: 确定选用哪种扫描策略
sort_buffer: 排序过程中确定是否需要创建临时表存储排序结果。每个线程共享。
两次扫描算法
1)、根据条件取出排序字段和行指针信息
2)、在sort_buffer中进行排序, 如果sort_buffer较小,产生临时表,在临时表存储排序结果
3)、根据排序结果的行号去主索引结构中获取数据
例如:select * from t where filed=‘abc’ order by field2
此语句会经过2次扫描
第1次搜索出符合条件的记录
第2次根据行号去获取字段
如果field字段上有索引,解析规则:use index, Using filesort
如果field字段上没有索引,则解析规则:Using where; Using filesort
说明:order by与索引无关; (除覆盖索引除外)
a. 一次扫描性能高,减少了io随机请求的次数
b. 排序操作是在内存(sort_buffer)里面进行的, 先select结果再进行排序,如果结果值大于max_length_for_sort_data 阀值设置需要二次io读取
c. 关联查询会产生临时表再进行order by
二、优化思路
a. 尽量减少io的读取 max_length_for_sort_data 阀值设置
b. 尽量使用有序排序输出。 运用覆盖索引、主键索引
c. 控制select 字段数,不需要的字段没必要输入
d. …….
一次扫描算法(4.1版本以后支持)
1)、根据条件取出所有字段信息
2)、在sort_buffer中进行排序, 如果sort_buffer较小,产生临时表,在临时表存储排序结果
选用一次排序扫描还是二次排序扫描, 需要根据参数来: max_length_for_sort_data
如果取的值 大于 max_length_for_sort_data 设置的值,采用二次扫描。
两个参数:
max_length_for_sort_data: 确定选用哪种扫描策略
sort_buffer: 排序过程中确定是否需要创建临时表存储排序结果。每个线程共享。
两次扫描算法
1)、根据条件取出排序字段和行指针信息
2)、在sort_buffer中进行排序, 如果sort_buffer较小,产生临时表,在临时表存储排序结果
3)、根据排序结果的行号去主索引结构中获取数据
例如:select * from t where filed=‘abc’ order by field2
此语句会经过2次扫描
第1次搜索出符合条件的记录
第2次根据行号去获取字段
如果field字段上有索引,解析规则:use index, Using filesort
如果field字段上没有索引,则解析规则:Using where; Using filesort
说明:order by与索引无关; (除覆盖索引除外)
阅读全文
0 0
- 理解mysql_order by排序原理及优化
- Mysql order by排序原理 以及 filesort优化
- 理解mysql_索引的原理及优化技巧
- 理解mysql_事务原理及常见优化思路
- jvm原理及优化
- jvm原理及优化
- JVM原理及优化
- jvm原理及优化
- listview原理及优化
- JVM原理及优化
- ListView原理及优化
- 浏览器原理及优化
- GC原理及优化
- 快速排序及优化
- 快速排序及优化
- 计数排序及优化
- 快速排序及优化
- 插入排序及优化
- 理解mysql_简述mvcc
- poj2531(dfs)Network Saboteur
- 一家人(寻找两个数的关系)
- Kafka的Log存储解析
- Java中static关键字的作用
- 理解mysql_order by排序原理及优化
- sudo apt-get update 问题
- Word中MathType公式与LaTeX公式的转换
- ios-野指针和僵尸对象
- dhtmlx5源码解析(二)全局方法分析date&&ajax
- 判断字符串是否没有重复字符(容易)
- apache依赖包apr的相关问题
- vim的一些基本操作
- 安装 node-sass 的正确姿势