B树和B+树的区别

本文介绍了B树和B+树的区别,包括叶子节点的指针、冗余索引和数据存储位置的差异。B+树更适合范围查询,其高度可能较B树高,尤其在MySQL中,由于页数据大小限制,B+树能更有效地存储大量数据。以16K的页大小为例,B+树可以存储2100万个元素,而B树需要6到7层,影响查询效率。推荐了一个数据结构学习网站供进一步研究。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

B树结构如下

B+树结构如下:

两种树的本质都是排好序的数据结构

不同点:

1.B树的叶子节点没有指针,B+树有,有指针可以更加方便范围查询,同一种范围查询,b树可能得多次从头节点开始遍历;

2.b树没有冗余索引,但是b+树有;

3.b树非叶子节点也存放数据,但是b+树只有叶子节点存放数据;

4.存放同样的数据,b树的高度可能比b+树要高。

-------------------------------------------------------------------------------------------------------------

为什么说可能要高呢?

因为mysql的页数据大小系统默认值是16K,结论可看下图sql查询数据。由于b树每个节点都带数据,而b+数只有叶子节点带数据。

以b+树为例,假如带节点的数据为1k,那么叶子节点可以存放16条数据,而第一层和第二层不带数据,索引所占空间大约为8B,下个节点的地址所占空间大约为6B,那么第一层和第二层每个节点大概可以放16*1024/(6+8)=1170个元素,那么3层结构可放的总元为:1170*1170*16=21902400

那么如果b树需要放21902400个元素则需要,16的n次方<21902400,求得n在6到7之间,所以如果用b树结构存储2100万个元素,树的层高为6,查询起来要慢很多。

最后推荐个学习数据结构的网站

数据结构学习网站https://www.cs.usfca.edu/~galles/visualization/Algorithms.html

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值