为什么一个磁盘块不能存储多个索引树节点

如何解决为什么一个磁盘块不能存储多个索引树节点

最近在研究index tree在数据库中的实现,了解到使用B+tree可以在一个磁盘块中存储尽可能多的key,这样搜索过程就可以读取尽可能少的磁盘。

>

但是我有一个问题,为什么一个磁盘块不能存储多个索引树节点?每个节点的指针可以设计为blockNumber + offset

解决方法

一个磁盘块当然可以存储多个索引树节点。您需要做的就是定义您想要的任何块大小,然后文件系统将其映射到正确的物理块。

通常您不想这样做,但主要是出于性能原因。随着时间的推移,树节点往往会分散在各个地方,然后将它们重新加载回来最终会加载一个完整的物理块。块中的其余节点可能不需要,但您支付的加载成本超出了您的需要。为了摊销成本,将节点大小与块大小相匹配是一个好主意。这有助于降低执行索引扫描的成本,因为无论如何您最终都会读取整个节点。

如果索引是以纯随机方式访问的,并且条目相对较小,那么节点大小是否小于物理块大小都没有关系。但是数据库的目标是通用的,他们并不真正提前知道索引最终将如何被使用。将节点大小与物理块大小匹配是一个安全的选择。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?