轉貼:收縮oracle表空間時ora-03297錯誤的解決

tonykorn97發表於2008-01-15
在實際使用中我們經常會遇到oracle某個表空間佔用了大量的空間而其中的資料量卻只佔用了少量空間,此時我們可以用ALTER DATABASE DATAFILE '***.dbf' RESIZE nnM的命令來收縮表空間,但在收縮的過程中會遇到ora-03297錯誤,表示在所定義的空間之後有資料存在,不能收縮,此時的解決辦法有:

1. 先估算該表空間內各個資料檔案的空間使用情況:

SQL>select file#,name from v$datafile;

SQL>select max(block_id) from dba_extents where file_id=11;

MAX(BLOCK_ID)
-------------
13657

SQL>show parameter db_block_size

NAME TYPE VALUE
----------------------------- ------- ----------- db_block_size integer 8192
SQL>select 13657*8/1024 from dual;

13657*8/1024
-----------
106.695313

這說明該檔案中最大使用塊位於106M與107M之間,

SQL> alter database datafile '/ora_data/cninsite/insitedev02.dbf' resize 100M;
alter database datafile '/ora_data/cninsite/insitedev02.dbf' resize 100M
*
ERROR at line 1:
ORA-03297: file contains used data beyond requested RESIZE value

SQL> alter database datafile '/ora_data/cninsite/insitedev02.dbf' resize 107M;

Database altered.

2.如果某些表佔用了資料檔案的最後一些塊,則需要先將該表匯出或移動到其他的表空間中,然後刪除表,再進行收縮。不過如果是移動到其他的表空間,需要重建其索引。

SQL> alter table t_obj move tablespace t_tbs1;

具體情況可以參考:

另外主意:alter tablespace xxx coalesce只能把相鄰的空餘資料塊連成一些比較大的空塊,但是不會移動當前的資料塊。

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

相關文章