B树和B+树定义

B树与B+树是两种常见的数据库索引结构。B树的特点包括每个节点最多有m个子节点,数据分散在各层节点中,导致查询性能不稳定。而B+树所有数据都存储在叶子节点,提供稳定查询和方便的范围查找。B+树适合大数据量存储,减少磁盘IO,但每个节点存储的数据相对较少。
摘要由CSDN通过智能技术生成

B树:

原则:一个m阶的B树(Balance Tree)具有如下几个特征:

  • 1、根结点至少两个子女
  • 2、每个中间节点都包含k-1个元素和k个孩子,其中 m/2 <= k <= m
  • 3、每一个叶子节点都包含k-1个元素,其中 m/2 <= k <= m
  • 4、所有的叶子结点都位于同一层
  • 5、每个节点中的元素从小到大排列,节点当中k-1个元素正好是k个孩子包含的元素的值域分划

   优势:

  • 存放同样多的元素时,树的高度变小了,相当于减少了磁盘IO次数,提升性能
  • 当查询进入了一个有很多元素的节点时,也只是存在于内存中进行比较,相对于磁盘IO的速度来说,消耗的时间可以忽略不计【这也是为什么在节点上进行“扩容”】

劣势:

  • 相对于B+树来说,每个节点都会存数据,同样大小的磁盘页存的节点元素会少些
  • 查询性能不稳定,比如有时可能会查到底层的叶子节点,有时可能查到最上层的根节点就返回了,每次查询的消耗不稳定,查询耗时波动大。
  • 范围查询不方便,比如图中我要查询符合6~10的所有元素,而6~10的元素从根节点开始就分布在2侧的树中,所以需要经过的中序遍历非常繁杂

m阶的B+树独有特征:

  • 有k个子树的中间节点包含有k个元素(B树中是k-1个元素),每个元素不保存数据只用来索引所有数据都保存在叶子节点
  • 所有的叶子结点中包含了全部元素的信息及指向含这些元素记录的指针,且叶子结点本身依关键字的大小自小而大顺序链接。
  • 所有的中间节点元素都同时存在于子节点,在子节点元素中是最大(或最小)元素。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值