B树和B+树

1.B+树相对B树,为什么IO次数更少?

为什么 B+ 树比 B 树更适合应用于数据库索引? B+树更加适应磁盘的特性,相比B树减少了I/O读写的次数。 由于索引文件很大因此索引文件存储在磁盘上,B+树的非叶子结点只存关键字不存数据,因而单个页可以存储更多的关键字,即一次性读入内存的需要查找的关键字也就越多,磁盘的随机I/O读取次数相对就减少了。

2.为什么B+树3层就可以存储4千万数据了?

参考:https://zhuanlan.zhihu.com/p/86137284

主键是int类型,4字节

同样的,若主键ID是int类型,长度为4字节,那么可以计算出1页中有指针数量=16K*1024/(6+4)=1600个

其实这也很好算,我们假设主键 ID 为 bigint 类型,长度为 8 字节,而指针大小在 InnoDB 源码中设置为 6 字节,这样一共 14 字节,我们一个页中能存放多少这样的单元,其实就代表有多少指针,即 16384/14=1170。

1G的内存,可以存储104857600个节点(条数据的索引)

相关推荐
sugar__salt8 小时前
从栈队列数据结构到JS原型面向对象全解
前端·javascript·数据结构
froyoisle10 小时前
CSP-J 历年复赛 T1 及解析(2019~2025)
数据结构·c++·算法·csp-j·csp·算法竞赛·信息学
喜欢打篮球的普通人11 小时前
LLVM 后端流程与关键数据结构:从 IR 到机器码的入门笔记
java·数据结构·笔记
Misnearch12 小时前
1、数组/字符串
java·数据结构·算法
008爬虫实战录12 小时前
【数据结构】 树、二叉树、完全二叉树,先序遍历、中序遍历、后序遍历
数据结构·算法
AllData公司负责人12 小时前
大模型赋能AllData数据中台,系列升级|通过联合智谱大模型与BiSheng开源项目,建设企业大模型应用开发平台,支持知识库向量检索!
大数据·数据结构·数据库·算法·大模型·向量数据库·智谱ai
梦想的颜色14 小时前
MySQL 数据存储结构与查询执行生命周期深度解析
运维·数据结构·数据库·mysql·线程·优化
Ameilide14 小时前
数据结构 算法解释,排序、查找
数据结构
真实的菜15 小时前
Redis 从入门到精通(二):深入数据结构 —— 从 RedisObject 到 SkipList 的源码级拆解
数据结构·redis·skiplist
小欣加油17 小时前
leetcode41 缺失的第一个正数
数据结构·c++·算法·leetcode