索引组织表

索引组织表
 
    索引组织表(IOT)不仅可以存储数据,还可以存储为表建立的索引。索引组织表的数据是根据主键排序后的顺序进行排列的,这样就提高了访问的速度。但是这是由牺牲插入和更新性能为代价的(每次写入和更新后都要重新进行重新排序)。
 
    索引组织表的创建格式如下:
    create table indextable(
       id varchar2(10),
       name varchar2(20),
       constraint pk_id primary key ( id )
      )
     organization index ;
 
    注意两点:
    ● 创建iot时,必须要设定主键,否则报错。
    ● 索引组织表实际上将所有数据都放入了索引中。
 
 
索引组织表属性
 
    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子句
 
    ● n的意义在于:指定压缩的列数。默认为无穷大。
 
    例如对于数据(1,2,3)、(1,2,4)、(1,2,5)、(1,3,4)、(1,3,5)时
    若使用compress则会将重复出现的(1,2)、(1,3)进行压缩
    若使用compress 1时,只对数据(1)进行压缩
 
 
索引组织表的维护
 
    索引组织表可以和普通堆表一样进行insert、update、delete、select操作。
    可使用alter table ... overflow语句来更改溢出段的属性。
 
    altertable t88 addoverflow; --新增一个overflow
 
    ● 要alter任何overview的属性,都必须先定义overflow,若建表时没有可以新增
 
    altertable t88 pctthreshold15includingname; --调整overflow的参数
    altertable t88 initrans2overflowinitrans4; --修改数据块和溢出段的initrans特性
 
    ● 关于initrans的概念参考 http://space.itpub.net/265709/viewspace-166534
 
 
索引组织表的应用


    heap table 就是一般的表,获取表中的数据是按命中率来得到的。没有明确的先后之分,在进行全表扫描的时候,并不是先插入的数据就先获取。数据的存放也是随机的,当然根据可用空闲的空间来决定。
 
     IOT 就是类似一个全是索引的表,表中的所有字段都放在索引上,所以就等于是约定了数据存放的时候是按照严格规定的,在数据插入以前其实就已经确定了其位置,所以不管插入的先后顺序,它在那个物理上的那个位置与插入的先后顺序无关。这样在进行查询的时候就可以少访问很多blocks,但是插入的时候,速度就比普通的表要慢一些。
适用于信息检索、空间和olap程序。
 
    索引组织表的适用情况:
    1、 代码查找表。
    2、 经常通过主码访问的表。
    3、 构建自己的索引结构。
    4、 加强数据的共同定位,要数据按特定顺序物理存储。
    5、 经常用between…and…对主码或唯一码进行查询。数据物理上分类查询。如一张订单表,按日期装载数据,想查单个客户不同时期的订货和统计情况。
 
    经常更新的表当然不适合IOT,因为oracle需要不断维护索引,而且由于字段多索引成本就大。
 
    如果不是经常使用主键访问表,就不要使用IOT
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle 数据库中,索引组织空间(Index-organized Tablespace,IOT)是一种特殊的空间类型,它主要用于存储索引组织(Index-organized table,IOT)。 索引组织是一种特殊的,它将数据存储在一个主索引结构中,而不是存储在一个数据区中。这样可以加快数据的检索速度,特别是在大型中查找数据时,可以显著提高查询效率。 索引组织空间与普通空间的区别在于,它使用了一种称为 B-tree 索引的数据结构来组织数据。在 B-tree 索引中,每个节点都包含了一些关键字和指向其他节点的指针,这样可以快速地查找目标数据。 索引组织空间可以使用以下 SQL 语句来创建: ```sql CREATE TABLESPACE iot_tablespace DATAFILE 'file_name' SIZE size EXTENT MANAGEMENT LOCAL UNIFORM SIZE uniform_extent_size SEGMENT SPACE MANAGEMENT AUTO; ``` 其中,`iot_tablespace` 是要创建的空间的名称,`file_name` 是要创建的数据文件的名称,`size` 是数据文件的初始大小,`uniform_extent_size` 是每个数据块的大小。 索引组织空间还可以使用以下 SQL 语句来管理: - ALTER TABLESPACE:用于修改索引组织空间的属性,例如修改空间的大小、添加数据文件等。 - DROP TABLESPACE:用于删除索引组织空间。 需要注意的是,在使用索引组织空间存储数据时,还需要使用 IOT 数据类型来定义,以及使用专门的 IOT 函数来操作 IOT 数据。此外,在使用索引组织空间时,还需要考虑备份和恢复的问题,必须正确地备份和恢复索引组织空间中的数据,以确保数据的完整性和可靠性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值