oracle重建索引的實(shí)現(xiàn)
oracle重建索引是我們經(jīng)常會(huì)用到的操作,下面就將為您詳細(xì)介紹oracle重建索引的實(shí)現(xiàn)方法,希望對您能夠有所幫助。
oracle重建索引有多種方式,如drop and re-create、rebuild、rebuild online等。下面簡單比較這幾種方式異同以及優(yōu)缺點(diǎn):
首先建立測試表及數(shù)據(jù):
- SQL> CREATE TABLE TEST AS SELECT CITYCODE C1 FROM CITIZENINFO2;
- Table created
- SQL> ALTER TABLE TEST MODIFY C1 NOT NULL;
- Table altered
- SQL> SELECT COUNT(1) FROM TEST;
- COUNT(1)
- ----------
- 16000000
一、drop and re-create和rebuild
首先看看正常建立索引時(shí),對表的加鎖情況。
- suk@ORACLE9I> @show_sid
- SID
- ----------
- 14
- suk@ORACLE9I> CREATE INDEX IDX_TEST_C1 ON TEST(C1);
索引已創(chuàng)建。
- SQL> SELECT OBJECT_NAME,LMODE FROM V$LOCK L,DBA_OBJECTS O WHERE O.OBJECT_ID=L.ID1 AND L.TYPE='TM' AND SID=14;
- OBJECT_NAME LMODE
- ------------------------------ ----------
- OBJ$ 3
- TEST 4
可見,普通情況下建立索引時(shí),oracle會(huì)對基表加share鎖,由于share鎖和 row-X是不兼容的,也就是說,在建立索引期間,無法對基表進(jìn)行DML操作。
對于刪除重建索引的方法就不介紹了,它與上面的描述是一樣的,下面我們看看用rebuild的方式建立索引有什么特別。
- suk@ORACLE9I> ALTER INDEX IDX_TEST_C1 REBUILD;
索引已更改。
另開一個(gè)會(huì)話,查詢此時(shí)test的加鎖情況:
- SQL> SELECT OBJECT_NAME,LMODE FROM V$LOCK L,DBA_OBJECTS O WHERE O.OBJECT_ID=L.ID1 AND L.TYPE='TM' AND SID=14;
- OBJECT_NAME LMODE
- ------------------------------ ----------
- TEST 4
可見,rebuild的方式對基表的加鎖方式與CREATE時(shí)是一樣的。
另開一個(gè)會(huì)話,在索引正在rebuild時(shí),執(zhí)行如下SQL:
- suk@ORACLE9I> SET AUTOTRACE TRACE
- suk@ORACLE9I> SELECT /*+ INDEX(TEST) */ COUNT(1) FROM TEST WHERE ROWNUM<10;
執(zhí)行計(jì)劃
- ----------------------------------------------------------
- SELECT STATEMENT Optimizer=CHOOSE (Cost=26 Card=1)
- 0 SORT (AGGREGATE)
- 1 COUNT (STOPKEY)
- 2 INDEX (FULL SCAN) OF 'IDX_TEST_C1' (NON-UNIQUE) (Cost=
- 26 Card=1986621)
可以看到oracle重建索引時(shí),查詢?nèi)匀豢梢允褂门f索引。實(shí)際上,oracle在rebuild時(shí),在創(chuàng)建新索引過程中,并不會(huì)刪除舊索引,直到新索引rebuild成功。
從這點(diǎn)可以知道rebuild比刪除重建的一個(gè)好處是不會(huì)影響原有的SQL查詢,但也正由于此,用rebuild方式建立索引需要相應(yīng)表空間的空閑空間是刪除重建方式的2倍。
【編輯推薦】
ORACLE系統(tǒng)表和數(shù)據(jù)字典視圖