oracle 索引組織表的深入詳解
更新時(shí)間:2013年05月31日 09:24:13 作者:
本篇文章是對oracle中索引組織表進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
索引組織表(IOT)不僅可以存儲(chǔ)數(shù)據(jù),還可以存儲(chǔ)為表建立的索引。索引組織表的數(shù)據(jù)是根據(jù)主鍵排序后的順序進(jìn)行排列的,這樣就提高了訪問的速度。但是這是由犧牲插入和更新性能為代價(jià)的(每次寫入和更新后都要重新進(jìn)行重新排序)。
索引組織表的創(chuàng)建格式如下:
create table indexTable(
ID varchar2 (10),
NAME varchar2 (20),
constraint pk_id primary key (ID)
)
organization index;
注意兩點(diǎn):
● 創(chuàng)建IOT時(shí),必須要設(shè)定主鍵,否則報(bào)錯(cuò)。
● 索引組織表實(shí)際上將所有數(shù)據(jù)都放入了索引中。
索引組織表屬性
1、OVERFLOW子句(行溢出)
因?yàn)樗袛?shù)據(jù)都放入索引,所以當(dāng)表的數(shù)據(jù)量很大時(shí),會(huì)降低索引組織表的查詢性能。此時(shí)設(shè)置溢出段將主鍵和溢出數(shù)據(jù)分開來存儲(chǔ)以提高效率。溢出段的設(shè)置有兩種格式:
PCTTHRESHOLD n :制定一個(gè)數(shù)據(jù)塊的百分比,當(dāng)行數(shù)據(jù)占用大小超出時(shí),該行的其他列數(shù)據(jù)放入溢出段
INCLUDING column_name :指定列之前的列都放入索引塊,之后的列都放到溢出段
● 當(dāng)行中某字段的數(shù)據(jù)量無法確定時(shí)使用PCTTHRESHOLD。
● 若所有行均超出PCTTHRESHOLD規(guī)定大小,則考慮使用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及之后的列必然被放入溢出列,而其他列根據(jù) PCTTHRESHOLD 規(guī)則。
2、COMPRESS子句(鍵壓縮)
與普通的索引一樣,索引組織表也可以使用COMPRESS子句進(jìn)行鍵壓縮以消除重復(fù)值。
具體的操作是,在organization index之后加上COMPRESS n子句
用于壓縮索引列,在塊級(jí)提取公因子,避免重復(fù)值。
如:
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;
表示對于每個(gè)主鍵組合都會(huì)物理地存儲(chǔ)。倘若使用COMPRESS N 則對于重復(fù)的列不再物理存儲(chǔ)。
● n的意義在于:指定壓縮的列數(shù)。默認(rèn)為無窮大。
例如對于數(shù)據(jù)(1,2,3)、(1,2,4)、(1,2,5)、(1,3,4)、(1,3,5)時(shí)
若使用COMPRESS則會(huì)將重復(fù)出現(xiàn)的(1,2)、(1,3)進(jìn)行壓縮
若使用COMPRESS 1時(shí),只對數(shù)據(jù)(1)進(jìn)行壓縮
索引組織表的維護(hù)
(1)、索引組織表可以和普通堆表一樣進(jìn)行INSERT、UPDATE、DELETE、SELECT操作。
(2)、可使用ALTER TABLE ... OVERFLOW語句來更改溢出段的屬性。
Alter table indextable add overflow;
(3)、要ALTER任何OVERVIEW的屬性,都必須先定義overflow,若建表時(shí)沒有可以新增
alter table t88 pctthreshold 15 including name; --調(diào)整overflow的參數(shù)
alter table t88 initrans 2 overflow initrans 4; --修改數(shù)據(jù)塊和溢出段的initrans特性
索引組織表的應(yīng)用
Heap Table 就是一般的表,獲取表中的數(shù)據(jù)是按命中率來得到的。沒有明確的先后之分,在進(jìn)行全表掃描的時(shí)候,并不是先插入的數(shù)據(jù)就先獲取。數(shù)據(jù)的存放也是隨機(jī)的,當(dāng)然根據(jù)可用空閑的空間來決定。
IOT 就是類似一個(gè)全是索引的表,表中的所有字段都放在索引上,所以就等于是約定了數(shù)據(jù)存放的時(shí)候是按照嚴(yán)格規(guī)定的,在數(shù)據(jù)插入以前其實(shí)就已經(jīng)確定了其位置,所以不管插入的先后順序,它在那個(gè)物理上的那個(gè)位置與插入的先后順序無關(guān)。這樣在進(jìn)行查詢的時(shí)候就可以少訪問很多blocks,但是插入的時(shí)候,速度就比普通的表要慢一些。索引組織表主要適用于信息檢索、空間和OLAP程序。
索引組織表的適用情況:
1、 代碼查找表。
2、 經(jīng)常通過主碼訪問的表。
3、 構(gòu)建自己的索引結(jié)構(gòu)。
4、 加強(qiáng)數(shù)據(jù)的共同定位,要數(shù)據(jù)按特定順序物理存儲(chǔ)。
5、 經(jīng)常用between…and…對主碼或唯一碼進(jìn)行查詢。
經(jīng)常更新的表當(dāng)然不適合IOT,因?yàn)閛racle需要不斷維護(hù)索引,而且由于字段多索引成本就大;如果不是經(jīng)常使用主鍵訪問表,就不要使用IOT。
IOT提供如下的好處:
·提高緩沖區(qū)緩存效率,因?yàn)榻o定查詢在緩存中需要的塊更少。
·減少緩沖區(qū)緩存訪問,這會(huì)改善可擴(kuò)縮性。
·獲取數(shù)據(jù)的工作總量更少,因?yàn)楂@取數(shù)據(jù)更快。
·每個(gè)查詢完成的物理I/O更少。
索引組織表的創(chuàng)建格式如下:
復(fù)制代碼 代碼如下:
create table indexTable(
ID varchar2 (10),
NAME varchar2 (20),
constraint pk_id primary key (ID)
)
organization index;
注意兩點(diǎn):
● 創(chuàng)建IOT時(shí),必須要設(shè)定主鍵,否則報(bào)錯(cuò)。
● 索引組織表實(shí)際上將所有數(shù)據(jù)都放入了索引中。
索引組織表屬性
1、OVERFLOW子句(行溢出)
因?yàn)樗袛?shù)據(jù)都放入索引,所以當(dāng)表的數(shù)據(jù)量很大時(shí),會(huì)降低索引組織表的查詢性能。此時(shí)設(shè)置溢出段將主鍵和溢出數(shù)據(jù)分開來存儲(chǔ)以提高效率。溢出段的設(shè)置有兩種格式:
PCTTHRESHOLD n :制定一個(gè)數(shù)據(jù)塊的百分比,當(dāng)行數(shù)據(jù)占用大小超出時(shí),該行的其他列數(shù)據(jù)放入溢出段
INCLUDING column_name :指定列之前的列都放入索引塊,之后的列都放到溢出段
● 當(dāng)行中某字段的數(shù)據(jù)量無法確定時(shí)使用PCTTHRESHOLD。
● 若所有行均超出PCTTHRESHOLD規(guī)定大小,則考慮使用INCLUDING。
復(fù)制代碼 代碼如下:
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及之后的列必然被放入溢出列,而其他列根據(jù) PCTTHRESHOLD 規(guī)則。
2、COMPRESS子句(鍵壓縮)
與普通的索引一樣,索引組織表也可以使用COMPRESS子句進(jìn)行鍵壓縮以消除重復(fù)值。
具體的操作是,在organization index之后加上COMPRESS n子句
用于壓縮索引列,在塊級(jí)提取公因子,避免重復(fù)值。
如:
復(fù)制代碼 代碼如下:
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;
表示對于每個(gè)主鍵組合都會(huì)物理地存儲(chǔ)。倘若使用COMPRESS N 則對于重復(fù)的列不再物理存儲(chǔ)。
● n的意義在于:指定壓縮的列數(shù)。默認(rèn)為無窮大。
例如對于數(shù)據(jù)(1,2,3)、(1,2,4)、(1,2,5)、(1,3,4)、(1,3,5)時(shí)
若使用COMPRESS則會(huì)將重復(fù)出現(xiàn)的(1,2)、(1,3)進(jìn)行壓縮
若使用COMPRESS 1時(shí),只對數(shù)據(jù)(1)進(jìn)行壓縮
索引組織表的維護(hù)
(1)、索引組織表可以和普通堆表一樣進(jìn)行INSERT、UPDATE、DELETE、SELECT操作。
(2)、可使用ALTER TABLE ... OVERFLOW語句來更改溢出段的屬性。
復(fù)制代碼 代碼如下:
Alter table indextable add overflow;
(3)、要ALTER任何OVERVIEW的屬性,都必須先定義overflow,若建表時(shí)沒有可以新增
復(fù)制代碼 代碼如下:
alter table t88 pctthreshold 15 including name; --調(diào)整overflow的參數(shù)
alter table t88 initrans 2 overflow initrans 4; --修改數(shù)據(jù)塊和溢出段的initrans特性
索引組織表的應(yīng)用
Heap Table 就是一般的表,獲取表中的數(shù)據(jù)是按命中率來得到的。沒有明確的先后之分,在進(jìn)行全表掃描的時(shí)候,并不是先插入的數(shù)據(jù)就先獲取。數(shù)據(jù)的存放也是隨機(jī)的,當(dāng)然根據(jù)可用空閑的空間來決定。
IOT 就是類似一個(gè)全是索引的表,表中的所有字段都放在索引上,所以就等于是約定了數(shù)據(jù)存放的時(shí)候是按照嚴(yán)格規(guī)定的,在數(shù)據(jù)插入以前其實(shí)就已經(jīng)確定了其位置,所以不管插入的先后順序,它在那個(gè)物理上的那個(gè)位置與插入的先后順序無關(guān)。這樣在進(jìn)行查詢的時(shí)候就可以少訪問很多blocks,但是插入的時(shí)候,速度就比普通的表要慢一些。索引組織表主要適用于信息檢索、空間和OLAP程序。
索引組織表的適用情況:
1、 代碼查找表。
2、 經(jīng)常通過主碼訪問的表。
3、 構(gòu)建自己的索引結(jié)構(gòu)。
4、 加強(qiáng)數(shù)據(jù)的共同定位,要數(shù)據(jù)按特定順序物理存儲(chǔ)。
5、 經(jīng)常用between…and…對主碼或唯一碼進(jìn)行查詢。
經(jīng)常更新的表當(dāng)然不適合IOT,因?yàn)閛racle需要不斷維護(hù)索引,而且由于字段多索引成本就大;如果不是經(jīng)常使用主鍵訪問表,就不要使用IOT。
IOT提供如下的好處:
·提高緩沖區(qū)緩存效率,因?yàn)榻o定查詢在緩存中需要的塊更少。
·減少緩沖區(qū)緩存訪問,這會(huì)改善可擴(kuò)縮性。
·獲取數(shù)據(jù)的工作總量更少,因?yàn)楂@取數(shù)據(jù)更快。
·每個(gè)查詢完成的物理I/O更少。
相關(guān)文章
Oracle數(shù)據(jù)塊實(shí)現(xiàn)原理深入解讀
Oracle對數(shù)據(jù)庫數(shù)據(jù)文件(datafile)中的存儲(chǔ)空間進(jìn)行管理的單位是數(shù)據(jù)塊(data block),本文將詳細(xì)介紹2012-11-11詳解Linux平臺(tái) Oracle 10gR2(10.2.0.5)RAC安裝 Part1:準(zhǔn)備工作
本篇文章主要介紹了Linux平臺(tái) Oracle 10gR2(10.2.0.5)RAC安裝 Part1:準(zhǔn)備工作 ,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-01-01ORALCE?substr函數(shù)及substrb與字符集關(guān)系詳解
這篇文章主要介紹了ORALCE?substr函數(shù)及substrb與字符集關(guān)系,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07Oracle中多表關(guān)聯(lián)批量插入批量更新與批量刪除操作
這篇文章主要介紹了Oracle中多表關(guān)聯(lián)批量插入,批量更新與批量刪除操作,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-12-12Oracle如何使用PL/SQL調(diào)試存儲(chǔ)過程
這篇文章主要介紹了Oracle如何使用PL/SQL調(diào)試存儲(chǔ)過程,文中通過圖文介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07解決Windows10不能安裝Oracle?11g的問題(附詳細(xì)安裝教程)
這篇文章介紹了解決Windows10不能安裝Oracle?11g的方法,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04Oracle In和exists not in和not exists的比較分析
一個(gè)是問in exist的區(qū)別,一個(gè)是not in和not exists的區(qū)別2009-08-08