数据库中的索引条目(index entry)是什么?
一、数据库中的索引条目(index entry)是什么
对于叶子节点块来说,其所包含的索引条目与分支节点一样,都是按照顺序排列的(缺省是升序排列,也可以在创建索引时指定为降序排列)。每个索引条目(也可以叫做每条记录)也具有两个字段。名列前茅个字段表示索引的键值,对于单列索引来说是一个值;而对于多列索引来说则是多个值组合在一起的。第二个字段表示键值所对应的记录行的ROWID,该ROWID是记录行在表里的物理地址。如果索引是创建在非分区表上或者索引是分区表上的本地索引的话,则该ROWID占用6个字节;如果索引是创建在分区表上的全局索引的话,则该ROWID占用10个字节。
知道这些信息以后,我们可以举个例子来说明如何估算每个索引能够包含多少条目,以及对于表来说,所产生的索引大约多大。对于每个索引块来说,缺省的PCTFREE为10%,也就是说非常多只能使用其中的90%。同时9i以后,这90%中也不可能用尽,只能使用其中的87%左右。也就是说,8KB的数据块中能够实际用来存放索引数据的空间大约为6488(8192×90%×88%)个字节。
假设我们有一个非分区表,表名为warecountd,其数据行数为130万行。该表中有一个列,列名为goodid,其类型为char(8),那么也就是说该goodid的长度为固定值:8。同时在该列上创建了一个B树索引。
在叶子节点中,每个索引条目都会在数据块中占一行空间。每一行用2到3个字节作为行头,行头用来存放标记以及锁定类型等信息。同时,在名列前茅个表示索引的键值的字段中,每一个索引列都有1个字节表示数据长度,后面则是该列具体的值。
延伸阅读:
二、索引原理
索引的存储原理大致可以概括为一句话:以空间换时间。
一般来说索引本身也很大,不可能全部存储在内存中,因此索引往往是存储在磁盘上的文件中的(可能存储在单独的索引文件中,也可能和数据一起存储在数据文件中)。
数据库在未添加索引进行查询的时候默认是进行全文搜索,也就是说有多少数据就进行多少次查询,然后找到相应的数据就把它们放到结果集中,直到全文扫描完毕。

猜你喜欢LIKE
相关推荐HOT
更多>>
线程池执行过程中遇到异常会发生什么,怎样处理?
线程池执行过程中遇到异常以及处理线程池执行过程中遇到异常会触发一系列的处理机制。当线程池中的某个线程抛出未捕获的异常时,线程将立即终止...详情>>
2023-10-16 22:10:11
为什么说PHP与Swoole是优异组合?
PHP与Swoole在Web开发和网络编程领域中,共同构成了一种强大的解决方案。什么是PHPPHP是一种广泛使用的开源服务器端脚本语言,特别适用于Web开...详情>>
2023-10-16 20:56:37
有什么好用的redis可视化管理工具?
一、Redis Desk较好 ManagerRedis Desk较好 Manager是一款非常受欢迎的Redis数据库管理工具。它支持直接进行数据修改、删除和新增等操作,而且...详情>>
2023-10-16 19:30:54
mysql怎么查询连续时间段的最大值?
一、mysql怎么查询连续时间段的最大值按仪器与时间(处理成小时)group by,计算值的数量与和,再根据结果判断值数量是否有缺失值,以及和的最...详情>>
2023-10-16 15:15:18热门推荐
Oracle怎么连接数据库?
沸git pull 和git fetch的区别?
热JDK动态代理为什么必须要基于接口?
热线程池执行过程中遇到异常会发生什么,怎样处理?
新HTTP协议中URI和URL有什么区别?
为什么说PHP与Swoole是优异组合?
显示器的 VGA、HDMI、DVI 和 DisplayPort 接口有什么区别?
如何删除需要使用管理员权限才能删除的文件?
有什么好用的redis可视化管理工具?
arm架构和x86架构有什么区别?
GitLab为什么选择Vue.js?
实现atoi函数时需要注意什么?
Ruby中为什么不能显式的调用私有方法?
与数据库的连接为什么会很耗时、耗费资源?
技术干货






