MySQL索引为什么用B+树而不是B树?

AI 概述
数据库索引结构影响查询效率,B 树与 B + 树均为平衡树,但 MySQL 选择 B + 树有三大关键原因:一是 B + 树非叶子节点仅存 key、数据集中在叶子节点,中间节点更小,减少磁盘 IO;二是所有查询均需走到叶子节点,路径稳定、性能可预测;三是叶子节点通过链表连接,支持高效范围查询。综上,B + 树的稳定性和范围查询能力,是其被 MySQL 选用的核心原因。
目录
文章目录隐藏
  1. 1、数据存储位置
  2. 2、查询路径稳定性
  3. 3、范围查询效率
  4. 总结

MySQL 索引为什么用 B+树而不是 B 树?

在数据库中,索引结构直接影响查询效率。

B 树和 B+树都是平衡树,但 MySQL 选择 B+树有 3 个关键原因:

1、数据存储位置

  • B 树:每个节点都存数据,数据分散在各层。
  • B+树:非叶子节点只存 key,所有数据都集中在叶子节点。
  • 优势:B+树让中间节点更小,树更高效,磁盘 IO 更少。

2、查询路径稳定性

  • B 树:有的查询可能在中间节点就找到,有的必须走到叶子节点,路径长度不一。
  • B+树:所有查询都走到叶子节点,路径一致。
  • 优势:稳定的查询路径让性能可预测。

3、范围查询效率

  • B 树:范围查询需要回溯多层节点,效率低。
  • B+树:叶子节点通过链表横向连接,可以顺序扫描范围。
  • 优势:支持高效的范围查询,是数据库最常用的操作类型。

总结

B+树赢的不是速度,而是稳定性和范围查询能力,这就是 MySQL 选择 B+树的核心原因。

以上关于MySQL索引为什么用B+树而不是B树?的文章就介绍到这了,更多相关内容请搜索码云笔记以前的文章或继续浏览下面的相关文章,希望大家以后多多支持码云笔记。

「点点赞赏,手留余香」

7

给作者打赏,鼓励TA抓紧创作!

微信微信 支付宝支付宝

还没有人赞赏,快来当第一个赞赏的人吧!

声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 admin@mybj123.com 进行投诉反馈,一经查实,立即处理!
重要:如软件存在付费、会员、充值等,均属软件开发者或所属公司行为,与本站无关,网友需自行判断
码云笔记 » MySQL索引为什么用B+树而不是B树?

发表回复