当前位置: 首页 > news >正文

2-003:MySQL 三层 B+ 树能存多少数据?

1. 计算 B+ 树能存储多少数据

参数设定
  • 每个数据页(Page)大小:16KB(16384 字节)
  • 每个索引节点存储的子节点数量:
    • 索引项大小:
      • 假设 bigint(主键)占 8 字节
      • 每个索引项存储 8(主键)+ 6(指针)= 14 字节
    • 每个 16KB 页能存储的索引项数:
      • 16384 / 14 ≈ 1170(即每个节点可存 1170 个子节点)
      • 即:每个节点(页),可以存储1170个索引节点

计算三层 B+ 树的存储量
  • 第一层(根节点):最多存储 1170 个指向中间节点的指针
  • 第二层(中间层):每个中间节点存储 1170 个指向叶子节点的指针,共 1170 × 1170 = 1369000 个指针
  • 第三层(叶子节点):
    • 每个叶子节点存储 16KB / 1KB = 16 条数据(假设数据记录大小为 1KB)
    • 总存储量:1369000 × 16 ≈ 21924000(约 2000 万条记录

2. 结论

三层 B+ 树在 MySQL InnoDB 中大约能存 2000 万条记录
✅ **如果增加一层(四层),则能存 1170 × 1170 × 1170 × 16 ≈ 25.6 亿条数据,数据量扩展能力极强!
B+ 树的层级较低,查询时磁盘 I/O 更少,性能更优!

这个计算方式比之前的百万级估算更加精准,关键在于 数据页大小、索引项大小、层级计算方式,可以用于实际评估 MySQL 索引的存储能力。🚀

相关文章:

  • torch.distributions.categorical.Categorical 介绍
  • 智慧停车小程序:实时车位查询、导航与费用结算一体化
  • Datawhale AI + 办公 笔记2
  • linux自启动服务
  • 使用 Tesseract 进行 OCR 识别的详细指南
  • Linux开发工具----vim
  • Room数据库的使用
  • STM32Cubemx-H7-7-OLED屏幕
  • 【Python】【数据分析】Python 数据分析与可视化:全面指南
  • 【Python 2D绘图】Matplotlib绘图(统计图表)
  • 【冯诺依曼:到底有什么重大贡献 关键字摘抄】
  • ngx_conf_param
  • JAVA面试_进阶部分_java中四种引用类型(对象的强、软、弱和虚引用)
  • 开发中常见状态码以及状态码用途
  • Mysql8.x常用命令
  • XXE 目录
  • 从零开发Chrome广告拦截插件:开发、打包到发布全攻略
  • 企业网设计
  • 【数据库】10分钟学会MySQL的增删改查:数据库、表、表记录操作指南
  • 数字电路逻辑代数 | 运算 / 定律 / 公式 / 规则 / 例解
  • 陕西澄城打造“中国樱桃第一县”:从黄土高原走向海外,年产值超30亿
  • A股26家游戏企业去年营收近1900亿元:过半净利下滑,出海成为主流选择
  • 成立6天的公司拍得江西第三大水库20年承包经营权,当地回应
  • 十四届全国政协原常委、民族和宗教委员会原副主任苟仲文被提起公诉
  • “五一”假期国内出游3.14亿人次,国内游客出游总花费1802.69亿元
  • 俄军击落多架企图攻击莫斯科的无人机