mysql中的mmr

mrr是什么
全称是 Multi-Range Read Optimization
将随机 IO 转化为顺序 IO 以降低查询过程中 IO 开销的一种手段
在这里插入图片描述
不开启mrr便会想上图一样,来回切换磁盘读取数据,降低了IO开销
在这里插入图片描述
对于 Myisam,在去磁盘获取完整数据之前,会先按照 rowid 排好序,再去顺序的读取磁盘。对于 Innodb,则会按照聚簇索引键值排好序,再顺序的读取聚簇索引。
优化器将二级索引查询到的记录放到一块缓冲区中;
如果二级索引扫描到文件的末尾或者缓冲区已满,则使用快速排序对缓冲区中的内容进行排序;
取数据;
取完数据,则继续调用过程 2) 3),直至扫描结束;

mrr的优点
1、磁盘和磁头不再需要来回的做机械运动;
2、可以充分利用磁盘预读
3、在一次查询中,每一页的数据只会从磁盘读取一次
索引本身就是为了减少磁盘 IO,加快查询,而 MRR,则是把索引减少磁盘 IO 的作用,进一步放大。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值