oracle索引组织表-----概述

原创 2010年06月01日 09:58:00

Heap Table 就是一般的表,获取表中的数据是按命中率来得到的。没有明确的先后之分,在进行全表扫描的时候,并不是先插入的数据就先获取。数据的存放也是随机的,当然根据可用空闲的空间来决定。
IOT 就是类似一个全是索引的表,表中的所有字段都放在索引上,所以就等于是约定了数据存放的时候是按照严格规定的,在数据插入以前其实就已经确定了其位置(这位置如何来确定的呢?),所以不管插入的先后顺序,它在那个物理上的那个位置与插入的先后顺序无关。这样在进行查询的时候就可以少访问很多blocks,但是插入的时候,速度就比普通的表要慢一些。

IOT有什么意义呢?使用堆组织表时,我们必须为表和表主键上的索引分别留出空间。而IOT不存在主键的空间开销,因为索引就是数据,数据就是索引,二者已经合二为一。但是,IOT带来的好处并不止于节约了磁盘空间的占用,更重要的是大幅度降低了I/O,减少了访问缓冲区缓存(尽管从缓冲区缓存获取数据比从硬盘读要快得多,但缓冲区缓存并不免费,而且也绝对不是廉价的。每个缓冲区缓存获取都需要缓冲区缓存的多个闩,而闩是串行化设备,会限制应用的扩展能力)
适用于信息检索、空间和OLAP程序。索引组织表的适用情况:
1、 代码查找表。
2、 经常通过主码访问的表。
3、 构建自己的索引结构。
4、 加强数据的共同定位,要数据按特定顺序物理存储。
5、 经常用between…and…对主码或唯一码进行查询。数据物理上分类查询。如一张订单表,按日期装载数据,想查单个客户不同时期的订货和统计情况。
经常更新的表不适合iot,因为oracle需要不断维护索引,而且由于字段多索引成本就大

IOT提供如下的好处:
·提高缓冲区缓存效率,因为给定查询在缓存中需要的块更少。
·减少缓冲区缓存访问,这会改善可扩缩性。
·获取数据的工作总量更少,因为获取数据更快。
·每个查询完成的物理I/O更少。
如果经常在一个主键或唯一键上使用between查询,也是如此。如果数据有序地物理存储,就能提升这些查询的性能。

索引组织表属性 

   1、OVERFLOW子句(行溢出)

 

    因为所有数据都放入索引,所以当表的数据量很大时,会降低索引组织表的查询性能。此时设置溢出段将主键和溢出数据分开来存储以提高效率。溢出段的设置有两种格式:

 

     PCTTHRESHOLD n:制定一个数据块的百分比,当行数据占用大小超出时,该行的其他列数据放入溢出段

     INCLUDING column_name:指定列之前的列都放入索引块,之后的列都放到溢出段

 

      ● 当行中某字段的数据量无法确定时使用PCTTHRESHOLD。

      ● 若所有行均超出PCTTHRESHOLD规定大小,则考虑使用INCLUDING。

     

   Create table t88(

     ID varchar2(10),

     NAME varchar2(20),

     Constraint pk_id primary key(ID)

     )

   Organization index

     PCTTHRESHOLD 20

     Overflow tablespace users

     INCLUDING name;

 

   ● 如上例所示,name及之后的列必然被放入溢出列,而其他列根据PCTTHRESHOLD规则。

 

   2、COMPRESS子句(键压缩) 

 

    与普通的索引一样,索引组织表也可以使用COMPRESS子句进行键压缩以消除重复值。

    具体的操作是,在organization index之后加上COMPRESS n子句

  用于压缩索引列,在块级提取公因子,避免重复值。

如:create table iot(

        owner, object_type, object_name,

        constraint iot_pk primary key(owner, object_type,object_name)

        Orgnazation index

        NOCOMPRESS

);

表示对于每个主键组合都会物理地存储。倘若使用COMPRESS N 则对于重复的列不再物理存储,

● n的意义在于:指定压缩的列数。默认为无穷大。 

    例如对于数据(1,2,3)、(1,2,4)、(1,2,5)、(1,3,4)、(1,3,5)时

    若使用COMPRESS则会将重复出现的(1,2)、(1,3)进行压缩

    若使用COMPRESS 1时,只对数据(1)进行压缩

 如NOCOMPRESS:

 owner , object_type,  object_name

 Scott    table          emp

 Scott    table          dept

 COMPRESS  1

 owner , object_type,  object_name

 Scott    table          emp

          table          dept

 COMPRESS 2

 owner , object_type,  object_name

 Scott    table          emp

          Dept

 

 

索引组织表的维护

 

    索引组织表可以和普通堆表一样进行INSERT、UPDATE、DELETE、SELECT操作。

    可使用ALTER TABLE ... OVERFLOW语句来更改溢出段的属性。

 

   Alter table t88 add overflow;--新增一个overflow

 

   ● 要ALTER任何OVERVIEW的属性,都必须先定义overflow,若建表时没有可以新增

 

   Alter table t88 pctthreshold 15 including name;--调整overflow的参数

   Alter table t88 initrans 2 overflow initrans 4;--修改数据块和溢出段的    initrans特性

TOMCAT下的JIVE2的中文问题分析及解决

TOMCAT下的JIVE2的中文问题的报告原文摘自jive论坛用户shyguy的帖子。翻译者:cheramiXXX 注意 XXX: 所有的结论都是基于一下平台:Winnt4.0(简体中文版) + Su...
  • cherami
  • cherami
  • 2001-09-21 18:12:00
  • 852

Oracle 11g笔记——索引组织表

一、索引组织表(Index-Organized Table, IOT)     索引组织表是一类特殊的表,它将索引和表的数据存储在一起。普通表的数据以无序(Heap)的方式存放在数据库中。     而...
  • lJean
  • lJean
  • 2016-05-10 09:14:09
  • 1782

索引组织表+创建索引组织表

索引组织表(不同于一般表) 1在存储时不是普通表那样采用堆组织的方式将数据无须的存放在数据段中,而是采用类似B树索引的索引组织方式将记录按照某个主键列排序后,再以B树的方式存在数据段中。2如果向索引...
  • zhou920786312
  • zhou920786312
  • 2017-05-28 21:26:52
  • 561

oracle索引组织表(Index Organizied Table)

索引组织表(index organized table, IOT)就是存储在一个索引结构中的表。存储在堆中的表是无组织的(也就是说,只要有可用的空间,数据可以放在任何地方),IOT中的数据则按主键存储...
  • yu766588220
  • yu766588220
  • 2017-02-13 17:14:38
  • 434

Oracle性能调优:堆组织表和索引组织表区别

 HOT和IOT的起源     堆组织表的存储速度因为不用考虑排序, 所以存储速度会比较快。 但是要查找符合某个条件的记录, 就必须得读取全部的记录以便筛选。     而这个时候为了加快查询...
  • u010667607
  • u010667607
  • 2015-02-06 13:00:20
  • 490

ORACLE堆表和索引组织表IOT优缺点

堆表: 缺点: 主键索引和表数据分离,增加数据所占用空间。可能主键索引的所占用的空间大于该表所对应的空间 添加或者修改索引字段时需要维护索引,索引还会产生日志。 增加IO次数(通过索引的rowid来查...
  • wo61356491
  • wo61356491
  • 2013-11-27 22:24:49
  • 1827

深入理解Oracle表(6):堆组织表(HOT)和索引组织表(IOT)的区别

深入理解Oracle表(6):堆组织表(HOT)和索引组织表(IOT)的区别        ㈠ HOT和IOT的起源                      堆组织表的存储速度因为...
  • haiross
  • haiross
  • 2014-11-13 13:44:02
  • 1377

堆组织表、索引组织表、索引聚簇表

--- 堆组织表就不说了,其索引中记录了记录所在位置的rowid,查找的时候先找索引,然后再根据索引rowid找到块中的行数据 索引组织表,其行数据以索引形式存放,因此找到索引,就等于找到了行...
  • pianzif
  • pianzif
  • 2014-06-18 12:49:33
  • 1389

索引组织表(IOT) compress参数优化存储空间

--IOT compress参数优化存储空间 EODA@PROD1> create table iot 2 ( owner, object_type, object_name, 3...
  • u013169075
  • u013169075
  • 2016-10-25 11:27:49
  • 190

堆组织表,索引组织表和索引聚簇表

1. 堆组织表:   通常我们默认建的表就是堆组织表。   语法:Create table test(      Id int,      Name varchar2(10)    );   此类型的...
  • Magister_Feng
  • Magister_Feng
  • 2011-07-07 14:25:04
  • 2119
收藏助手
不良信息举报
您举报文章:oracle索引组织表-----概述
举报原因:
原因补充:

(最多只允许输入30个字)