B+ 树(B+ Tree)——数据库索引的核心数据结构

B+ 树是多路平衡搜索树 ,专为磁盘 / 页式存储 设计,是 MySQL InnoDB、Oracle、PostgreSQL 等数据库索引的事实标准


一、B+ 树长什么样

核心结构特征

  • 多叉:一个节点可包含多个 key(降低树高)
  • 所有数据只在叶子节点
  • 叶子节点有序 + 双向链表
  • 非叶子节点只存 key + 指针(不存数据)

二、B+ 树 vs 二叉搜索树(为什么不用 BST)

对比项 二叉搜索树 B+ 树
分支数 2 多路
树高 很低
磁盘 IO 极少
范围查询 极强

数据库瓶颈在磁盘 IO,而不是 CPU

B+ 树通过**"矮胖结构"**,将一次查询控制在 2~4 次磁盘 IO


三、B+ 树 vs B 树(高频面试点)

对比 B 树 B+ 树
数据存储 所有节点 仅叶子节点
叶子节点 无链表 双向链表
范围查询 低效 极高效
磁盘利用率 一般 更高

数据库选择 B+ 树的根本原因:范围查询 + 顺序 IO


四、B+ 树为什么特别适合索引

1. 磁盘友好(页模型)

  • 一个节点 ≈ 一个数据页(16KB)
  • 一次 IO 读一整个节点
  • 分支因子极大(几百)

百万级数据,树高通常 ≤ 3


2. 范围查询性能极佳

sql 复制代码
WHERE id BETWEEN 100 AND 200
  • 定位到第一个叶子节点
  • 沿着叶子链表顺序扫描
  • 无回溯、顺序 IO

3. 排序天然有序

sql 复制代码
ORDER BY id
  • 直接按叶子节点顺序读取
  • 避免 filesort

五、B+ 树的基本操作流程

查找

  1. 从根节点开始
  2. 二分查找 key 区间
  3. 一路向下
  4. 命中叶子节点

插入

  • 插入到叶子节点
  • 节点满 → 分裂
  • 中间 key 上推
  • 可能级联到根

始终保持平衡


删除

  • 删除 key
  • 节点过少 → 向兄弟借
  • 借不到 → 合并
  • 可能向上调整

六、B+ 树在 MySQL InnoDB 中的真实形态

1. 聚簇索引(主键)

  • 叶子节点 = 整行数据
  • 数据物理顺序 ≈ 主键顺序

2. 二级索引

  • 叶子节点 = 索引列 + 主键值
  • 查询需要 回表

七、为什么不用 Hash / 跳表 / 红黑树

结构 问题
Hash ❌ 不支持范围查询
红黑树 ❌ 树高太高
跳表 ❌ 磁盘局部性差
B+ 树 ✅ 全面适合

八、一句话面试总结(背这个)

B+ 树是一种多路平衡搜索树,所有数据存储在叶子节点,叶子节点通过链表相连,极大降低树高和磁盘 IO 次数,特别适合范围查询和排序,因此成为数据库索引的标准实现。


相关推荐
NineData1 天前
NineData智能数据管理平台新功能发布|2026年1-2月
数据库·sql·数据分析
IvorySQL1 天前
双星闪耀温哥华:IvorySQL 社区两项议题入选 PGConf.dev 2026
数据库·postgresql·开源
ma_king1 天前
入门 java 和 数据库
java·数据库·后端
jiayou641 天前
KingbaseES 实战:审计追踪配置与运维实践
数据库
NineData2 天前
NineData 迁移评估功能正式上线
数据库·dba
NineData2 天前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
赵渝强老师2 天前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
全栈老石2 天前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
倔强的石头_3 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou644 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库