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+树。
相关推荐
未若君雅裁1 小时前
MySQL索引原理-InnoDB-B+树结构与查询过程
b树·mysql
爱炼丹的James2 小时前
第二章 数据结构
数据结构
不知名的忻2 小时前
关键路径(Java)
java·数据结构·算法·关键路径
C雨后彩虹2 小时前
SpringBoot整合Redis String,全套原生API讲解,覆盖80%缓存业务场景
java·数据结构·spring boot·redis·string
孬甭_2 小时前
顺序表详解
c语言·数据结构
qeen872 小时前
【算法笔记】各种常见排序算法详细解析(上)
c语言·数据结构·c++·学习·算法·排序算法
青山师3 小时前
数组与链表深度解析:从内存布局到工业级实践
数据结构·算法·链表·数组·算法与数据结构
AI机器学习算法6 小时前
机器学习基础知识
数据结构·人工智能·python·深度学习·算法·机器学习·ai学习路线
刀法如飞13 小时前
Ontology本体论是什么数据结构?Palantir 技术原理介绍
数据结构·人工智能·ai编程·图论