`
- 浏览:
2185664 次
-
深入理解Oracle表(6):堆组织表(HOT)和索引组织表(IOT)的区别
㈠ HOT和IOT的起源
堆组织表的存储速度因为不用考虑排序, 所以存储速度会比较快. 但是要查找符合某个条件的记录, 就必须得读取全部的记录以便筛选.
而这个时候为了加快查询速度, 索引就出现了, 索引是针对少量特定字段的值拿出来进行排序存储, 并记录在表中的位置,
而因为索引是有序的, 所以就会很容易通过索引查询到具体的记录位置, 然后再根据记录位置直接从表中读取该记录.
同时因为索引的字段较少, 所以索引通常会比其基表小得多.
从上面通过索引访问表记录的方式可以看出, 当要访问的数据量较大时, 通过每一条记录的位置去访问原始记录,
每一条符合条件的记录都需要经过索引访问后再访问基表这样一个复杂的过程, 这会花费很多时间,
同样, 如果不经过索引而直接查询表, 也可能因为表字段太多, 记录较大的情况下把全部的数据读取进来, 这也会花费很多时间.
那怎么办呢?
这个时候就会想到, 如果表中数据本身就是有序的, 这样查询表的时候就可以快速的找到符合条件的记录位置,
而很容易判断符合条件记录的位置, 这样只需要读取一小部分数据出来就可以了, 不需要全表记录都读取出来进行判断.
索引表就这样产生了.当然索引表中插入,更新资料的时候可能会因为需要排序而将数据重组, 这时候数据插入或更新速度会比堆组织表慢一些.
如果堆组织表上有索引, 那么对堆组织表的插入也会因为要修改索引而变慢
我们可以看到堆组织表+索引的方式 与 索引表 都能够实现数据的快速查找, 那为什么不全部采用索引表呢, 这样不是很简单吗?
我能想到的是前者我们可以针对不同的查找条件建立多个索引, 而后者却不行, 后者只能对某一组查询条件有效.
当然了,索引表上查询任何记录都是走索引的, 因为它本身就是索引结构.
当查询条件不符合指定条件时, 必须走 index full sacn , 需要扫描全部索引.
这就是说这时无法利用索引表已经根据某些字段排序的事实.也即排序对于这个查询来说无用.
而符合指定的条件时就会走 index range scan
㈡ 定义
① 堆组织表,其索引中记录了记录所在位置的rowid,查找的时候先找索引,然后再根据索引rowid找到块中的行数据。索引和表数据是分离的
② 索引组织表,其行数据以索引形式存放,因此找到索引,就等于找到了行数据。索引和数据是在一起的
㈢ 查找过程
① 堆组织表
一般索引大概3-5层,比如rowid为007,那么要找到007可能会先从第一层找<1000,再在第二层找到<100
然后在第三层找到007(注意这已经是3次I/O)
接着再通过007中标识的rowid去对应的磁盘上读取块中的行数据(第4次I/O)
② 索引组织表
前面的步骤同上,但是找到007后,由于数据和索引在一起,因此不必再找什么rowid,直接返回结果了
分享到:
Global site tag (gtag.js) - Google Analytics
相关推荐
索引组织表(IOT)不仅可以存储数据,还可以存储为表建立的索引。索引组 织表的数据是根据主键排序后的顺序进行排列的,这样就提高了访问的速度。 但是这是由牺牲插入和更新性能为代价的(每次写入和更新后都要重新进行...
索引组织表(IOT)不仅可以存储数据,还可以存储为表建立的索引。索引组织表的数据是根据主键排序后的顺序进行排列的,这样就提高了访问的速度。但是这是由牺牲插入和更新性能为代价的(每次写入和更新后都要重新进行...
3 、rebuild online 时系统会产生一个 SYS_JOURNAL_xxx 的 IOT 类型的系统临时日志表 , 所有 rebuild online 时索引的变化都记录在这个表中 , 当新的索引创建完成后 , 把这个表的记录维护到新的索引中去 , 然后 ...
亚太地区半导体行业:IoT半导体:欢迎来到无线世界2021.4.22(68页).pdf
IEC-白皮书:IoT 2020:智能和安全的IoT平台(英)-2019.9-187页精品报告.pdf
Machine Learning and IoT: A Biological Perspective ISBN-10 书号: 1138492698 ISBN-13 书号:: 9781138492691 Edition 版本: 1 Release Finelybook 出版日期: 2018-07-03 pages 页数 (374 ) $179.95 Book ...
对NB-IOT解释,加强NB-IOT运用理解,学习网络通信和窄带广域网络理解
26页《阿里云:IoT商业园区解决方案》.pdf
喜马拉雅:IoT助力流量稳定增长,三轮驱动变现效率加速提升(2022)(24页).pdf
书籍 , IoT and Azure>的第七章:IoT and Microservices
物联网数据分析:IOT INSIGHT在数字工厂场景的落地(2022)(33页).pdf
RISC-V:异构IoT时代全新架构.pdf
360IoT战略曝光:打造IoT全新家庭安全大脑.docx360IoT战略曝光:打造IoT全新家庭安全大脑.docx
360IoT战略曝光:打造IoT全新家庭安全大脑.pdf360IoT战略曝光:打造IoT全新家庭安全大脑.pdf
ODU全称为Oracle Database Unloader,是类似于Oracle的DUL的软件,用于直接从Oracle数据库的数据文件中获取表数据。在各种原因造成的数据库不能打开时,用于抢救数据,最大限度地减少数据丢失。 ODU有什么功能特点...
IoT 2020:智能安全的物联网平台白皮书 IEC白皮书中文版
假设: 数据将为JSON格式数据将根据配置格式进行处理转换和格式化是在Reekoh中完成的,而在插件中只需进行最少的转换正确配置了指定表的字段过程数据将直接写入指定的Oracle主机存储插件将仅使用简单SQL-Insert语句...