浅析存储引擎(3)-B-tree

 

浅析日志结构的存储引擎(1)-bitcask
浅析日志结构的存储引擎(2)-SSTable和LSM-Tree

前面两篇文章介绍了比较好理解的日志结构引擎LSM-Tree,但它们不是最常见的索引类型。目前最广泛使用的索引结构是B-tree。B-tree维护着按key排序的key-value对,这样可以实现高效的key-value查找和区间查询。

一、B-tree的存储

前面的文章提到,日志结构存储引擎将数据库分解为可变大小的段,并且始终按顺序写入段(追加写)。而B-tree将数据库分解成固定大小的块和页,通常是PAGESIZE大小4KB(也可能更大),页是读/写的最小单元,这种设计也符合磁盘的读取规则。

以mysql为例,我们都知道InnoDB的存储数据格式是按主键排序的(MyISAM和InnoDB的区别),数据都存储在最底层叶子节点。某一页被指定为B-Tree的根,如下图:

假设我们需要查找key=251,需要沿着200-300的区间,最后找到一个包含单个key=251的父

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值