当前位置: 首页 > 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 索引的存储能力。🚀

http://www.dtcms.com/a/62877.html

相关文章:

  • 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的增删改查:数据库、表、表记录操作指南
  • 数字电路逻辑代数 | 运算 / 定律 / 公式 / 规则 / 例解
  • MySQL创建数据库和表,插入四大名著中的人物
  • Node.js中HTTPS模块应用详解
  • 虚拟电商-数据库分库分表
  • PROC程序报无效的字符串或缓冲区长度问题
  • Java HashMap 底层原理
  • 【YOLO】AutoDL 训练模型
  • Python+DeepSeek:开启AI编程新次元——从自动化到智能创造的实战指南
  • Java三种注释方式
  • 【漫话机器学习系列】132.概率质量函数(Probability Mass Function, PMF)
  • 体验开源openeuler openharmony stratovirt模拟器