面试题:反推B+树高度

一个表5000w数据,一个数据行大小为1k,主键为long类型数据,假设指针大小为8B,页大小为16K,求B+树的高度?

B+树的非叶子节点存储key和指针,叶子节点存储数据,对应表中的某些行。

叶子节点存储的行数:16k/1k=2^4

需要叶子节点数:5000w/2^4

一个索引页能存储的索引个数:16k/(8+8)=2^10

树的高度:(2^10)^(h-1)=5000w/2^4

得出h≈3.15

千万级别的数据,b+树的高度也能维持3~5的高度,io次数也非常小。

相关推荐
咸甜适中2 小时前
rust语言学习笔记Trait(十五)Drop(释放资源)
笔记·学习·rust
八解毒剂2 小时前
查找-从二分查找到二叉排序树
数据结构·c++·算法
haven-8522 小时前
mysql索引当中的B+树,聚簇/二级索引,最左匹配,失效场景
数据库·b树·mysql
Knight_AL2 小时前
深入理解 ForkJoinPool、parallelStream、CompletableFuture:从原理到生产最佳实践(含百万订单统计实战)
java
IT笔记2 小时前
【Rust】 Rust宏学习笔记
笔记·学习·rust
tianxingjian20192 小时前
从欧盟电池法新规看QFD:如何将合规需求转化为技术特性?
笔记
程序猿追2 小时前
画个饼,给数据点颜色看看——在 HarmonyOS 模拟器上手搓一个饼图/环形图组件
深度学习·算法·harmonyos
秦明月132 小时前
EPLAN部件库整理之维护篇----部件库整理收尾:做好日常维护,再也不用反复重做
经验分享·其他·职场和发展·学习方法·设计规范
喜樂的CC3 小时前
NestJS图解笔记
笔记