Innodb为什么选B系列树

1. B系列树 和 红黑树 选择差异

  • 每个数据都要一个结点联系或存储,当数据量很大那么结点也会增大,因此平衡系列的树的高度会增高,不利于查找.
  • 平衡系列的树存储数据零散,不利于从磁盘里获取并插入大量的数据,需要多次IO.
  • B+树,拆分成子问题就是 每个page里有一个页目录和一批连续的数据,查找时通过页目录能快速的查找page里的数据;
  • 当有多个page组成时,最底层的是叶子数据; 上层的page里的页目录管理下层的所有page,不断的这样子,最后形成B+树.
  • 即B+树由page组成,page里可以存放数据也可以存放页目录,存放数据的必须在叶子page里.
  • 当我们查找数据时,通过页目录查找,再到下一个页目录查找,依次迭代,页目录查找可以批量的排除数据.
  • 在 MySQL里 page的大小为16kb,也就是page能够存储一批连续的数据,很明显能减少IO交互的次数.
  • 并且B+树它是向右向上增长的,向上增长的速度非常非常慢,大量的数据可能也就最多3层的高度,它的查找时间复杂度为O(logm n)以m为底,n为真数.

在这里插入图片描述

  • 叶子结点通过链表连接,方便遍历.
  • 小结:
  • 创建索引就是给数据排序,然后创建B+树,存放到磁盘里; 启动时只需要拿取根节点即可, 后续按需将磁盘数据连接到B+数上即可

2. B+树在哪里?

+ 在磁盘上有完整的B+树和数据
+ 在内存中有局部高频被访问的B+的核心Page,Page为B+树的叶子或者非叶子节点
+ mysql查找一定会伴生这mysql进行根据B+树进行page的换人换出.
+ 补充:
+ mysql其实也就是一个文件系统而已,我们打开文件,实际就是将磁盘文件的属性加载到内存里,文件系统进行文件结构的换入换出的操作.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

2023框框

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值