mrr是什么
全称是 Multi-Range Read Optimization
将随机 IO 转化为顺序 IO 以降低查询过程中 IO 开销的一种手段
不开启mrr便会想上图一样,来回切换磁盘读取数据,降低了IO开销
对于 Myisam,在去磁盘获取完整数据之前,会先按照 rowid 排好序,再去顺序的读取磁盘。对于 Innodb,则会按照聚簇索引键值排好序,再顺序的读取聚簇索引。
优化器将二级索引查询到的记录放到一块缓冲区中;
如果二级索引扫描到文件的末尾或者缓冲区已满,则使用快速排序对缓冲区中的内容进行排序;
取数据;
取完数据,则继续调用过程 2) 3),直至扫描结束;
mrr的优点
1、磁盘和磁头不再需要来回的做机械运动;
2、可以充分利用磁盘预读
3、在一次查询中,每一页的数据只会从磁盘读取一次
索引本身就是为了减少磁盘 IO,加快查询,而 MRR,则是把索引减少磁盘 IO 的作用,进一步放大。