??? 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ù)分開(kāi)來(lái)存儲(chǔ)以提高效率。溢出段的設(shè)置有兩種格式:
?
????? PCTTHRESHOLD n :制定一個(gè)數(shù)據(jù)塊的百分比,當(dāng)行數(shù)據(jù)占用大小超出時(shí),該行的其他列數(shù)據(jù)放入溢出段
????? INCLUDING column_name :指定列之前的列都放入索引塊,之后的列都放到溢出段
?
??????● 當(dāng)行中某字段的數(shù)據(jù)量無(wú)法確定時(shí)使用PCTTHRESHOLD。
????? ● 若所有行均超出PCTTHRESHOLD規(guī)定大小,則考慮使用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及之后的列必然被放入溢出列,而其他列根據(jù)
PCTTHRESHOLD
規(guī)則。
?
??? 2、COMPRESS子句(鍵壓縮)
?
??? 與普通的索引一樣,索引組織表也可以使用COMPRESS子句進(jìn)行鍵壓縮以消除重復(fù)值。
??? 具體的操作是,在organization index之后加上COMPRESS n子句
?
??? ● n的意義在于:指定壓縮的列數(shù)。默認(rèn)為無(wú)窮大。
?
??? 例如對(duì)于數(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í),只對(duì)數(shù)據(jù)(1)進(jìn)行壓縮
?
?
索引組織表的維護(hù)
?
??? 索引組織表可以和普通堆表一樣進(jìn)行INSERT、UPDATE、DELETE、SELECT操作。
??? 可使用ALTER TABLE ... OVERFLOW語(yǔ)句來(lái)更改溢出段的屬性。
?
??? altertable t88 addoverflow; --新增一個(gè)overflow