为什么要有区?

为什么要有区?

B+树中每个结点对应一个页,每层之间的页和页之间是通过双向链表相连的,但这只是逻辑上的相连,在磁盘中可能这两个页之间相距很远。而当我们进行范围查询的时候,会先找到最左边的记录和最右边的记录,然后开始遍历查找,当最左边的记录和最后边的记录在物理磁盘上的地址相差很大的时候,此时就会产生随机IO,而磁盘IO所消耗的时间和内存级别查询所消耗的时间可不要是一个数量级的,相差很大,所以我们应该尽量让在逻辑上相邻的页在磁盘上页相邻,那么我们在进行范围查找的时候就会产生顺序IO,顺序IO很快的

一个区包含连续的64个页,在innodb存储引擎中,一个页的大小为16kb,所以一个区的大小为1M,在表的数据量很大的时候,就不会在按照页为单位来存储索引数据了,而是按照区为单位存储,甚至当存储的数据量特别大的时候,可能一次性会会分配多个连续的区来存储索引数据,虽然会造成一点点空间浪费(数据不足以填充满整个区),但从性能的角度看,可以消除很多随机IO,功大于过

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

C_x_330

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值