B树和B+树的区别

B树 vs B+树

核心一句话:B+树只有叶子存数据、非叶子只存索引;B树所有节点都存数据。B+树更适合数据库、文件系统。

1. 节点存储内容(最核心区别)

  • B树
    每个节点(包括非叶子、叶子 )都存 关键字 + 数据/记录
  • B+树
    • 非叶子节点 :只存索引关键字,不存真实数据
    • 叶子节点 :存放全部数据记录,且叶子节点链表相连

2. 关键字与子节点关系

  • B树:n 个关键字 → n+1 个子节点
  • B+树:n 个关键字 → n 个子节点

3. 查找方式

  • B树:数据分散在各层,找到即停,可能在非叶子命中
  • B+树 :所有查找必须走到叶子节点 ;支持范围查询、全表遍历(顺着叶子链表走)

4. 磁盘IO(数据库重点)

  • B+树优势更大
    非叶子节点更小,一页能存更多索引 ,树更矮,磁盘IO次数更少。
    范围查询只遍历叶子链表,效率极高。

5. 应用场景

  • B树:文件系统索引(如NTFS)
  • B+树:MySQL InnoDB 索引、数据库主流索引结构

标准回答

  1. B树所有节点都存数据,B+树只有叶子存数据,非叶子只存索引。
  2. B+树非叶子节点更小,索引密度更高,树高更低,磁盘IO更少。
  3. B+树叶子节点连成链表,范围查询、排序、全表扫描远快于B树,所以MySQL用B+树。
相关推荐
刘马想放假2 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠3 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦10 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠11 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾11 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres82111 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q11 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒11 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记11 天前
单项不带头不循环链表
数据结构·链表
小糯米60111 天前
JS 数组
数据结构·算法·排序算法