oracle的臨時表空間解決問題的步驟

gyanp發表於2012-04-11

     正式資料庫伺服器,不能隨便重啟資料庫。

1、首先檢視當前的資料庫預設表空間:

SQL>select * from database_properties where property_name='DEFAULT_TEMP_TABLESPACE';

確認當前的臨時表空間為TEMP

2、檢視目前臨時表空間的大小:

SQL>select file_name,tablespace_name,bytes/1024/1024 "MB",autoextensible from dba_temp_files;

3、建立新的臨時表空間:

SQL> create temporary tablespace temp02

       tempfile '/oracle/oms/oradata/undo/temp02.dbf'  size 512M autoextend  on/off;

4、把新建的臨時表空間卻換成資料庫的預設臨時表空間

SQL> alter database default temporary tablespace temp02;

5、確認目前資料庫的預設臨時表空間

SQL>select * from database_properties where property_name='DEFAULT_TEMP_TABLESPACE';

確認temp02為當前的資料庫預設表空間

6、在刪除temp臨時表空間之前,先把執行在temp臨時表空間的sql語句kill掉,這樣的sql語句多為排序的語句

SQL>Select se.username,se.sid,se.serial#,su.extents,su.blocks*to_number(rtrim(p.value))as Space,

tablespace,segtype,sql_text

from v$sort_usage su,v$parameter p,v$session se,v$sql s

where p.name='db_block_size' and su.session_addr=se.saddr and s.hash_value=su.sqlhash

and s.address=su.sqladdr

order by se.username,se.sid;

查詢出來之後,kill掉這些sql語句:

SQL>alter system kill session '524,778';

確認在temp臨時表空間中沒有執行的sql語句之後,則可以刪除temp臨時表空間資料檔案了

7、刪除temp臨時表空間

SQL> drop tablespace temp including contents and datafiles;

相關文章