溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

數(shù)據(jù)庫(kù)中如何收縮臨時(shí)表空間及處理ORA-03297錯(cuò)誤

發(fā)布時(shí)間:2021-11-10 13:56:30 來(lái)源:億速云 閱讀:466 作者:小新 欄目:關(guān)系型數(shù)據(jù)庫(kù)

這篇文章主要為大家展示了“數(shù)據(jù)庫(kù)中如何收縮臨時(shí)表空間及處理ORA-03297錯(cuò)誤”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“數(shù)據(jù)庫(kù)中如何收縮臨時(shí)表空間及處理ORA-03297錯(cuò)誤”這篇文章吧。

當(dāng)我們進(jìn)行手動(dòng)resize的時(shí)候報(bào)如下錯(cuò)誤


  1. SQL> alter database tempfile '/u01/app/oracle/oradata/orcl/temp01.dbf' resize 16G;

  2. alter database tempfile '/u01/app/oracle/oradata/orcl/temp01.dbf' resize 16G

  3. *

  4. ERROR at line 1:

  5. ORA-03297: file contains used data beyond requested RESIZE value


  6. SQL> alter database tempfile '/u01/app/oracle/oradata/orcl/temp01.dbf' resize 20G;

  7. alter database tempfile '/u01/app/oracle/oradata/orcl/temp01.dbf' resize 20G

  8. *

  9. ERROR at line 1:

  10. ORA-03297: file contains used data beyond requested RESIZE value





我們采用交換臨時(shí)表空間方式,收縮臨時(shí)表空間
新建臨時(shí)表空間


  1. SQL> CREATE TEMPORARY TABLESPACE temp2 tempfile '/u01/app/oracle/oradata/orcl/temp201.dbf' size 4G autoextend on next 20M maxsize 8G;

  2. Tablespace created.

  3. SQL> ALTER DATABASE DEFAULT TEMPORARY TABLESPACE TEMP2;

  4. Database altered.

  5. SQL> select * from (select username,temporary_tablespace from dba_users) where rownum<10;

  6. USERNAME        TEMPORARY_TABLESPACE

  7. ------------------------------ ------------------------------

  8. SYS        TEMP2

  9. SYSTEM        TEMP2

  10. OUTLN        TEMP2

  11. DIP        TEMP2

  12. ORACLE_OCM        TEMP2

  13. APPQOSSYS        TEMP2

  14. WMSYS        TEMP2

  15. XS$NULL TEMP2

  16. EXFSYS        TEMP2

此時(shí)刪除原臨時(shí)表空間,發(fā)現(xiàn)一直hang在那里

  1. SQL> DROP TABLESPACE TEMP INCLUDING CONTENTS AND DATAFILES;


查詢正在使用臨時(shí)表空間事務(wù)我們是測(cè)試環(huán)境直接kill(正式環(huán)境慎用,等一段時(shí)間再drop)

  1. SQL> SELECT 'ALTER SYSTEM KILL SESSION ''' || sid ||','|| serial# || '''immediate;' FROM v$session where saddr in (SELECT session_addr FROM v$sort_usage WHERE tablespace='TEMP2');

  1. SQL> DROP TABLESPACE TEMP INCLUDING CONTENTS AND DATAFILES;

  2. Tablespace dropped.


刪除臨時(shí)表空間完成

以上是“數(shù)據(jù)庫(kù)中如何收縮臨時(shí)表空間及處理ORA-03297錯(cuò)誤”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI