【学习笔记】B+树和skipList的时间复杂度都是O(log n),为什么mysql底层要用B+树而不用skipList?

因为B+tree比跳跃表的检索效率更高,数据分部的更均匀。

跳跃表是通过二路分治的方式实现logN。
B+Tree是通过多路分治的方式实现logN。

当数据表的数据足够多的时候,B+tree的根节点~任何一块叶子节点的路径是固定的。而skiplist的头节点~目标节点的路径是不固定的。所以检索的value越大,skiplist的路径就越深,磁盘的io次数就越多。

B+tree的所有叶子节点构成了一个双向循环链表,每一块叶子节点可以存储一条或者多条数据。这种结构不管是一条记录、还是多条记录查询都能节省磁盘IO。

skiplist的每一个节点只存储一条记录,对于一条记录的查询是比较节省磁盘io,对于多条记录的查询,skiplist的磁盘IO次数会比B+tree要多。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值