我的编程空间,编程开发者的网络收藏夹
学习永远不晚

数据库中如何计算索引高度和索引段大小

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

数据库中如何计算索引高度和索引段大小

这篇文章主要介绍数据库中如何计算索引高度和索引段大小,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

B*-Tree level (depth of the index from its root block to its leaf blocks). 
A depth of 0 indicates that the root block and leaf block are the same.

假如一个字段长为50字节,总计1000万行

需要多少个block的叶子节点
叶子节点的一个条目=字段键值+rowid=50+6=56B
一个block容量=8KB
block=1000万*56/8K=7万

需要多少block二级分支节点
分支节点的一个条目=字段键值+rowid=50+6=56B
一个block容量=8KB
block=7万*56/8K=490

需要多少block一级分支节点
分支节点的一个条目=字段键值+rowid=50+6=56B
一个block容量=8KB
block=490*56/8K=3.43

需要多少根节点
根节点的一个条目=字段键值+rowid=50+6=56B
一个block容量=8KB
block=3.43*56/8K=0.0.2

得出结论索引高度为3,索引段大小=(1+4+490+7万)*8KB=563M
如果字段长度为10,则索引段大小=(4/5+490/5+7万/5)*8KB=112M,索引高度为2,因为4/5小于1,所以一级分支节点就不要再分了,就是根节点了




一个索引条目最小为7B(字段1B大小,rowid 6B大小),一个索引块最多可以存放8K/7=1142个索引条目,根节点最多指向1142个分支节点,分支节点最多指向1142个叶子节点
索引高度为0,索引段最大8KB
索引高度为1,索引段最大(1+1142)*8KB=8.92M
索引高度为2,索引段最大(1+1142+1142*1142)*8KB=10G
索引高度为3,索引段最大(1+1142+1142*1142+1142*1142*1142)*8KB=11T

折中一下,平时一个字段20B,索引条目26B,一个索引块最多可以存放307个索引条目,根节点最多指向307个分支节点,分支节点最多指向307个叶子节点
索引高度为0,索引段最大8KB
索引高度为1,索引段最大(1+307)*8KB=2.4M
索引高度为2,索引段最大(1+307+307*307)*8KB=739M
索引高度为3,索引段最大(1+307+307*307+307*307*307)*8KB=221G

以上是“数据库中如何计算索引高度和索引段大小”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

数据库中如何计算索引高度和索引段大小

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

PHP如何带索引检查计算数组的差集,用回调函数比较数据和索引

本篇介绍了使用PHP回调函数计算数组差集的方法,其中差集的元素是仅存在于第一个数组中,且不满足回调函数定义的相等条件(考虑数据和索引)。回调函数用于自定义比较,返回布尔值指示相等性。文章提供了示例代码,展示了如何使用array_diff_uassoc()函数和回调函数来计算差集。
PHP如何带索引检查计算数组的差集,用回调函数比较数据和索引
2024-04-02

Java如何带索引检查计算数组的差集,用回调函数比较数据和索引

带索引检查计算Java数组差集。使用回调函数比较元素,返回元素和索引。该方法灵活、可扩展、可维护。它通过遍历一个数组,并使用回调函数在另一个数组中检查每个元素是否存在来实现。如果不存在,则将元素和索引添加到差集中。示例演示了如何使用该方法计算两个数组的差集。
Java如何带索引检查计算数组的差集,用回调函数比较数据和索引
2024-04-02

如何通过索引优化PHP与MySQL的计算字段和JSON数据的查询?

引言:在PHP和MySQL开发中,经常会涉及到计算字段和JSON数据的查询需求。然而,由于这两种查询都会带来较高的计算量和数据处理复杂度,如果不加以优化,可能会导致性能下降。本文将介绍如何通过索引优化PHP与MySQL的计算字段和JSON数
2023-10-21

PHP如何带索引检查计算数组的交集,用单独的回调函数比较数据和索引

本文介绍了使用PHP计算数组交集的两种方法,包括常规方法(array_intersect())和带索引检查的方法(array_uintersect())。后者使用回调函数比较数据和索引。此外,还提供了一个使用array_map()函数的备用方法。通过示例代码和说明,文章展示了如何实现这些方法来计算具有索引检查的数组交集。
PHP如何带索引检查计算数组的交集,用单独的回调函数比较数据和索引
2024-04-02

Java如何带索引检查计算数组的交集,用单独的回调函数比较数据和索引

本文讲解如何利用回调函数比较数据和索引,计算Java数组的交集。算法步骤是遍历数组,调用回调函数比较元素,检查索引是否相等,然后将结果添加到新数组中。回调函数用于自定义比较标准,如值相等性或对象引用相等性。示例代码使用Integer数组,以值相等性和索引相等性计算交集,结果为[3,4,5]。
Java如何带索引检查计算数组的交集,用单独的回调函数比较数据和索引
2024-04-02

AndoridSQLite数据库开发中如何添加索引

本篇文章为大家展示了AndoridSQLite数据库开发中如何添加索引,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。AndoridSQLite数据库开发添加索引索引是一种通过预先排序和对表的一个或多
2023-06-04

编程热搜

目录