MySQL索引为什么选择B+树而不是B树

B类树的特点,B类树保证尽量多的在结点上存储相关的信息,同时保证层数尽量的少,查找更快,磁盘的IO操作也少一些。

  1. B+树的IO更少:B+树的非叶子节点没有指向关键字具体信息的指针,只用作索引,因此B+树的非叶子节点比B树占用更少磁盘空间。当数据量大时,一次不能把整个索引全部加载到内存,只能逐个加载每一个磁盘块,而关键字所占空间更小可以使得一次性读入内存的索引也就越多,IO次数也就越少。

  2. B+树更擅长范围查找和遍历:B+树的叶子节点是按顺序放置的双向链表,更适合MySQL的区间查询。B树因为其分支结点同样存储着数据,需要进行一次中序遍历按序。B+树只需要去遍历叶子节点就可以实现整棵树的遍历,更适合MySQL的扫表操作。B树则需要进行深度优先遍历或层序遍历。

  3. B+树的查询效率更加稳定:B+树叶子节点(数据)都在同一层,查找操作从根节点到叶子节点经历的路径长度相同,所以查询效率稳定。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值