降低Oracle高水位線的方法

kisslfcr發表於2015-07-29
1. 執行表重建指令 alter table table_name move(驗證不可行,不降低水位線,但可釋放表空間)
當你建立了一個物件如表以後,不管你有沒有插入資料,它都會佔用一些塊,ORACLE也會給它分配必要的空間.同樣,用ALTER TABLE MOVE釋放自由空間後,還是保留了一些空間給這個表.

ALTER TABLE ... MOVE 後面不跟引數也行,不跟參數列還是在原來的表空間,Move後記住重建索引.
查詢失效索引語句:select index_name,table_name,tablespace_name,status From dba_indexes Where owner='HNUNICOM' And status<>'VALID';
重建索引語句:alter index INDEX_NAME rebuild tablespace TABLESPACE_NAME;
如果以後還要繼續向這個表增加資料,沒有必要move,只是釋放出來的空間,只能這個表用,其他的表或者segment無法使用該空間。

2. 執行alter table table_name shrink space;(已經驗證成功,推薦使用,可釋放資料庫和磁碟空間空間,大表可同時降低表自身和表空間的高水位線,小表則只可以降低表自身的高水位線,原因不詳)
注意,此命令為Oracle 10g新增功能,執行該指令之前必須允許行移動 alter table table_name enable row movement;


3. 複製要保留的資料到臨時表t,drop原表,然後rename臨時表t為原表(未驗證)

4. 用EXP匯出後,刪除原表/表空間,之後用IMP重新匯入(驗證成功)

5. Alter table table_name deallocate unused(驗證不可行,不降低水位線)
注:這證明,DEALLOCATE UNUSED為釋放HWM上面的未使用空間,但是並不會釋放HWM下面的自由空間,也不會移動HWM的位置.

6. 儘量使用truncate(驗證不可行,不降低水位線,可釋放資料庫空間,但truncate後表預設空間大小為刪除前的空間大小,如想釋放計算機磁碟空間,需要用方法2壓縮)

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

相關文章