索引組織表(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 t88_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 VARCHAR2(8),
object_type VARCHAR2(8),
object_name VARCHAR2(8),
constraint iot_pk primary key(owner, object_type,object_name))
organization 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)進行壓縮
索引組織表的維護
(1)、索引組織表可以和普通堆表一樣進行INSERT、UPDATE、DELETE、SELECT操作。
(2)、可使用ALTER TABLE ... OVERFLOW語句來更改溢出段的屬性。複製代碼 代碼如下:Alter table indextable add overflow;
(3)、要ALTER任何OVERVIEW的屬性,都必須先定義overflow,若建表時沒有可以新增複製代碼 代碼如下:alter table t88 pctthreshold 15 including name; --調整overflow的參數
alter table t88 initrans 2 overflow initrans 4; --修改資料區塊和溢出段的initrans特性
索引組織表的應用
Heap Table 就是一般的表,擷取表中的資料是按命中率來得到的。沒有明確的先後之分,在進行全表掃描的時候,並不是先插入的資料就先擷取。資料的存放也是隨機的,當然根據可用閒置空間來決定。
IOT 就是類似一個全是索引的表,表中的所有欄位都放在索引上,所以就等於是約定了資料存放的時候是按照嚴格規定的,在資料插入以前其實就已經確定了其位置,所以不管插入的先後順序,它在那個物理上的那個位置與插入的先後順序無關。這樣在進行查詢的時候就可以少訪問很多blocks,但是插入的時候,速度就比普通的表要慢一些。索引組織表主要適用於資訊檢索、空間和OLAP程式。
索引組織表的適用情況:
1、 代碼尋找表。
2、 經常通過主碼訪問的表。
3、 構建自己的索引結構。
4、 加強資料的共同定位,要資料按特定順序實體儲存體。
5、 經常用between…and…對主碼或唯一碼進行查詢。
經常更新的表當然不適合IOT,因為oracle需要不斷維護索引,而且由於欄位多索引成本就大;如果不是經常使用主鍵訪問表,就不要使用IOT。
IOT提供如下的好處:
·提高緩衝區快取效率,因為給定查詢在緩衝中需要的塊更少。
·減少緩衝區快取訪問,這會改善可擴縮性。
·擷取資料的工作總量更少,因為擷取資料更快。
·每個查詢完成的物理I/O更少。