摘要:

堆表:又称堆组织表,常用的表类型,以堆的方式管理,当增加数据时,将使用段中第一个适合数据大小的空闲空间。当删除数据时,留下的空间允许以后的DML操作重用。 堆组织表(heap table)

应用中99%(或者更多)的情况下使用的可能都是堆组织表,不过随着IOT的出现,这种状况以后可能会有所改观,因为IOT本身就可以加索引。执行 CREATE TABLE语句时,默认得到的表类型就是堆组织表。如果你想要任何其他类型的表结构,就需要在CREATE语句本身中指定它。

堆 (heap)是计算机科学领域中得到深入研究的一种经典数据结构。它实际上就是一个很大的空间、磁盘或内存区(当然,这里所说的磁盘是指数据库表的相应磁 盘),会以一种显然随机的方式管理。数据会放在最合适的地方,而不是以某种特定顺序来放置。许多人希望能按数据放入表中的顺序从表中取出数据,但是对于 堆,这是无法保证的。这一点很容易说清楚。 参见:

oracle表类型  http://suntengjiao1.blog.163.com/blog/static/99211088200982522251123/

㈠ 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,直接返回结果了

oracle索引分类与区分,深入理解Oracle表(6):堆组织表(HOT)和索引组织表(IOT)的区别...相关推荐

  1. oracle delete原理,如何恢复并理解oracle删除数据的原理

    对于误DROP表的情况,也可以直接用闪回方法恢复数据(要保证被删除数据的块没被覆写).由于oracle在删除表时,没有直接清空表所占的块,oracle把这些已删除的表的信息放到了一个虚拟容器" ...

  2. Oracle 索引 详解 - 索引分类

    二. 索引分类 Oracle提供了大量索引选项.知道在给定条件下使用哪个选项对于一个应用程序的性能来说非常重要.一个错误的选择可能会引发死锁,并导致数据库性能急剧下降或进程终止.而如果做出正确的选择, ...

  3. 《深入理解Oracle 12c数据库管理(第二版)》PDF

    一:下载获取位置: 二:本书图样: 三:本书目录: 图书目录: 第1章 安装Oracle 1.1 了解OFA 1.1.1 Oracle清单目录 1.1.2 Oracle基础目录 1.1.3 Oracl ...

  4. oracle 10046详解,深入理解Oracle调试事件:10046事件详解

    之前也写过一篇10046的文章:10046简介 今天,Think想和大家一起共同深入去理解一下Oracle的这些调试事件 10046事件是SQL_TRACE的扩展,被戏称为"吃了兴奋剂的SQ ...

  5. 深入理解Oracle RAC 12c 笔记

    深入理解Oracle RAC 12c 跳转至: 导航. 搜索 文件夹 1 概述 2 集群件管理和故障诊断 3 执行实践 4 新特性 5 存储和ASM 6 应用设计上的问题 7 管理和调优一个复杂的RA ...

  6. oracle正确使用索引,通过案例学调优之--Oracle中null使用索引

    通过案例学调优之--Oracle中null使用索引 默认情况下,Oracle数据库,null在Index上是不被存储的,当在索引列以"is null"的方式访问时,无法使用索引:本 ...

  7. 深入理解Oracle表(5):三大表连接方式详解之Hash Join的定义,原理,算法,成本,模式和位图

    Hash Join只能用于相等连接,且只能在CBO优化器模式下.相对于nested loop join,hash join更适合处理大型结果集        Hash Join的执行计划第1个是has ...

  8. 索引使用的好处与坏处(Oracle测试)

    创建索引的好处 –帮助用户提高查询速度 –利用索引的唯一性来控制记录的唯一性 –可以加速表与表之间的连接 –降低查询中分组和排序的时间 创建索引的坏处 –存储索引占用磁盘空间 –执行数据修改操作(IN ...

  9. 深入理解Oracle的并行操作

    并行(Parallel)和OLAP系统  并行的实现机制是:首先,Oracle会创建一个进程用于协调并行服务进程之间的信息传递,这个协调进程将需要操作的数据集(比如表的数据块)分割成很多部分,称为并行 ...

最新文章

  1. PyTorch 源码解读之分布式训练了解一下?
  2. 开涛spring3(2.1) - IoC基础
  3. 《算法图解》第四章笔记与课后练习_快速排序算法
  4. hdu 5254(暴力穷举)
  5. FPGA实现OV5640摄像头及RGB图像数据采集
  6. gamaredon_Gamaredon组织某样本分析
  7. 文字旋转_技术宅大白教你用软件做抖音爆火的文字旋转视频
  8. vue 前端设置允许跨域_[web]记一次sanic+vue跨域问题
  9. HDU 1085 Holding Bin-Laden Captive!
  10. php 系统找不到指定的路径.,PHP网站(windows2003服务器 IIS6)提示:系统找不到指定的路径。...
  11. 二分法05:搜索旋转排序数组
  12. 【转】Redis的各项功能解决了哪些问题?
  13. Mac Osx X86 10.4.7,确实不错
  14. 大学四年,学了这些计算机基础知识,成为了别人眼中的大神
  15. #2013年Google官方技术求职大礼包#面试求职技巧篇
  16. 最新的JavaScript知识总结,欢迎各位大佬指正,需要的留下邮箱,给你们发原稿(PDF版)...
  17. zabbix5部署+Grafana大屏展示
  18. 3D NAND 前沿
  19. 20多份软件测试报告模板(标准版)一份优秀测试报告模板流程
  20. 查看电脑上安装的所有的python版本以及安装路径

热门文章

  1. window电脑查看ssh公钥,以及将自己的公钥添加到Github等类似网站
  2. C++ primer第六章函数的学习
  3. 解决Dr.com上不了网的问题
  4. C++STL与泛型编程(4)OOP(面向对象编程) Vs. GP(泛型编程)
  5. Java提高篇 —— String缓冲池
  6. Androud 如何有效减少重复代码
  7. 时间即财富:创业者浪费精力的八个错误
  8. springCloud - 第10篇 - 服务间调用追踪 (zipkin 的使用)
  9. Vector:动态数组的使用和说明
  10. hdoj2553(N皇后问题)