Oracle11gr2不可用索引不佔用空間

yangtingkun發表於2010-01-10

11gr2中,對於不可用索引,Oracle會自動將對應的資料段釋放,避免不可用的索引佔用空間。

 

 

首先看看10g下的情況:

SQL> SELECT * FROM V$VERSION;

BANNER
----------------------------------------------------------------
Oracle Database 10g Enterprise Edition Release 10.2.0.3.0 - 64bi
PL/SQL Release 10.2.0.3.0 - Production
CORE    10.2.0.3.0      Production
TNS for Linux: Version 10.2.0.3.0 - Production
NLSRTL Version 10.2.0.3.0 - Production

SQL> CREATE TABLE T_INDEX
  2  AS SELECT * FROM DBA_OBJECTS;

Table created.

SQL> CREATE INDEX IND_T_INDEX_NAME
  2  ON T_INDEX(OBJECT_NAME);

Index created.

SQL> SELECT SEGMENT_NAME, BYTES/1024
  2  FROM USER_SEGMENTS
  3  WHERE SEGMENT_NAME = 'IND_T_INDEX_NAME';

SEGMENT_NAME                   BYTES/1024
------------------------------ ----------
IND_T_INDEX_NAME                     3072

SQL> ALTER INDEX IND_T_INDEX_NAME UNUSABLE;

Index altered.

SQL> SELECT SEGMENT_NAME, BYTES/1024
  2  FROM USER_SEGMENTS
  3  WHERE SEGMENT_NAME = 'IND_T_INDEX_NAME';

SEGMENT_NAME                   BYTES/1024
------------------------------ ----------
IND_T_INDEX_NAME                     3072

即使索引被置於不可用狀態,索引段仍然存在。

下面看看11gr2環境下的情況:

SQL> SELECT * FROM V$VERSION;

BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
PL/SQL Release 11.2.0.1.0 - Production
CORE    11.2.0.1.0      Production
TNS for Linux: Version 11.2.0.1.0 - Production
NLSRTL Version 11.2.0.1.0 - Production

SQL> CREATE TABLE T_INDEX
  2  AS SELECT * FROM DBA_OBJECTS;

表已建立。

SQL> CREATE INDEX IND_T_INDEX_NAME
  2  ON T_INDEX(OBJECT_NAME);

索引已建立。

SQL> SELECT SEGMENT_NAME, BYTES/1024
  2  FROM USER_SEGMENTS
  3  WHERE SEGMENT_NAME = 'IND_T_INDEX_NAME';

SEGMENT_NAME                   BYTES/1024
------------------------------ ----------
IND_T_INDEX_NAME                     3072

SQL> ALTER INDEX IND_T_INDEX_NAME UNUSABLE;

索引已更改。

SQL> SELECT SEGMENT_NAME, BYTES/1024
  2  FROM USER_SEGMENTS
  3  WHERE SEGMENT_NAME = 'IND_T_INDEX_NAME';

未選定行

正如文章開頭介紹的,在11.2中,如果索引被至於UNUSABLE狀態,則資料庫會自動將索引對應的段釋放,避免不可用的索引還佔有資料檔案空間。

 

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/4227/viewspace-624776/,如需轉載,請註明出處,否則將追究法律責任。

相關文章