MySQL InnoDB MRR优化指南
前言
MRR 是 Multi-Range Read 的简写,目的是减少磁盘随机访问,将随机访问转化为较为顺序的访问。适用于 range/ref/eq_ref 类型的查询。
实现原理:
1、在二级索引查找后,根据得到的主键到聚簇索引找出需要的数据。
2、二级索引查找得到的主键的顺序是不确定的,因为二级索引的顺序与聚簇索引的顺序不一定一致;
3、如果没有 MRR,那么在聚簇索引查找时就可能出现乱序读取数据页,这对于机械硬盘是及其不友好的。
4、MRR 的优化方式:
将查找到的二级索引键值放在一个缓存中; 将缓存中的键值按照 主键 进行排序; 根据排序后的主键去聚簇索引访问实际的数据文件。5、当优化器使用了 MRR 时,执行计划的 Extra 列会出现 “Using MRR” 。
6、如果查询使用的二级索引的顺序本身与结果集的顺序一致,那么使用 MRR 后需要对得到的结果集进行排序。
使用 MRR 还可以减少缓冲池中页被替换的次数,批量处理对键值的查询操作。
可以使用命令 select @@optimizer_switch; 查看是否开启了 MRR:
index_merge=on,index_merge_union=on,index_merge_sort_union=on,index_merge_intersection=on,engine_condition_pushdown=on,index_condition_pushdown=on,mrr=off,mrr_cost_based=on,block_nested_loop=on,batched_key_access=off,materialization=on,semijoin=on,loosescan=on,firstmatch=on,duplicateweedout=on,subquery_materialization_cost_based=on,use_index_extensions=on,condition_fanout_filter=on,derived_merge=on,use_invisible_indexes=off,skip_scan=on
mrr_cost_based=on 表示是否通过 cost based 的方式来选择使用 MRR 。
用 set @@optimizer_switch='mrr=on/off'; 命令开启或关闭 MRR 。
select @@read_rnd_buffer_size ; 参数用来控制键值的缓冲区大小,默认 256K,当大于该参数值时,执行器根据主键对已缓存的数据进行排序,然后再通过主键取得行数据。
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对免费资源网的支持。
栏 目:其它数据库
下一篇:MySQL5.6解压版服务无法启动之系统错误1067问题
本文标题:MySQL InnoDB MRR优化指南
本文地址:https://zz.feitang.co/shujuku/30984.html
您可能感兴趣的文章
- 12-31hiredis从安装到项目实战操作
- 12-31phpmyadmin登录时怎么指定服务器ip和端口
- 12-31MySQL线上死锁分析实战
- 12-31MySQL 触发器的使用和理解
- 12-31MySQL 字段默认值该如何设置
- 12-31Redis主从同步配置的方法步骤(图文)
- 12-31MySQL 字符串拆分操作(含分隔符的字符串截取)
- 12-31redis 交集、并集、差集的具体使用
- 12-31MySQL精讲之二:DML数据操作语句
- 12-31PostgreSQL判断字符串是否包含目标字符串的多种方法


阅读排行
推荐教程
- 12-07mysql中外链接是什么意思?
- 12-23PL/SQL登录Oracle数据库报错ORA-12154:TNS:无法解析指定的连接标识符
- 12-07mysql的数据类型有哪些?
- 12-07电脑中找不到mysql服务怎么办
- 12-07mysql如何设置禁止远程连接
- 12-07mysql数据库表格怎么建立
- 12-07关于Redis原子计数器incr,防止并发请求
- 12-07MySQL索引能让查询效率提高这么多原因是?
- 12-07mysql更改用户密码命令有哪些
- 12-05mysql的事务,隔离级别和锁用法实例分析




