臨時表空間使用率過高的解決辦法
1.執行下述SQL,佔用TEMP表空間較大的session資訊一目瞭然
SELECT V.INST_ID,
V.SID,
V.SERIAL#,
V.USERNAME,
V.STATUS,
V.ACTION,
V.MACHINE,
V.MODULE,
V.OSUSER,
V.TERMINAL,
V.PROGRAM,
V.SQL_ID,
SU.TABLESPACE,
(SU.BLOCKS *
TO_NUMBER((SELECT RTRIM(VALUE)
FROM V$PARAMETER P
WHERE P.NAME = 'db_block_size'))) / 1024 / 1024 AS SIZE_M,
(SELECT ROUND(SUM(BYTES) / (1024 * 1024), 3) FROM V$TEMPFILE) TEMP_TS_SIZE_M,
ROUND((SU.BLOCKS *
TO_NUMBER((SELECT RTRIM(VALUE)
FROM V$PARAMETER P
WHERE P.NAME = 'db_block_size'))) * 100 /
(SELECT SUM(BYTES)
FROM V$TEMPFILE),
3) C_USED_PERCENT,
SU.SEGTYPE,
(SELECT A.SQL_TEXT
FROM GV$SQLAREA A
WHERE A.SQL_ID = NVL(V.SQL_ID,SU.SQL_ID)
AND A.INST_ID = V.INST_ID
AND ROWNUM = 1) SQL_TEXT,
SU.SEGFILE#,
SU.SEGBLK#,
SU.EXTENTS,
SU.BLOCKS,
SU.SEGRFNO#
FROM GV$SORT_USAGE SU, --GV$TEMPSEG_USAGE
GV$SESSION V
WHERE SU.SESSION_ADDR = V.SADDR
AND SU.INST_ID = V.INST_ID
ORDER BY SU.INST_ID, SU.BLOCKS DESC
GV$SORT_USAGE與GV$TEMPSEG_USAGE可以互相替代。
檢視GV$SORT_USAGE中的SEGTYPE列的不同的值所代表的含義如下所示:
SORT:SQL排序使用的臨時段,包括ORDER BY、GROUP BY、DISTINCT、視窗函式、合併查詢(UNION、INTERSECT、MINUS)、索引的建立(CREATE)和重建(REBUILD)、ANALYZE分析表等產生的排序。
DATA:臨時表(GLOBAL TEMPORARY TABLE)儲存資料使用的段。
INDEX:臨時表上建的索引使用的段。
HASH:HASH演算法,如HASH連線所使用的臨時段。
LOB_DATA和LOB_INDEX:臨時LOB使用的臨時段。
2.分析佔用率過高的會話,確保會話異常或SQL異常後,可以清理該會話:
ALTER SYSTEM KILL SESSION 'SID,SERIAL#' IMMEDIATE;
3.會話清理後如表空間不釋放,可採用下述辦法釋放空間:
SELECT TS#, NAME FROM V$TABLESPACE WHERE NAME='TEMP';
ALTER SESSION SET EVENTS 'IMMEDIATE TRACE NAME DROP_SEGMENTS LEVEL 4';
其中,LEVEL後的值為TS#+1。在以上例子中,TEMP表空間的TS#為3,所以TS#+1=4。
4.其他簡單粗暴的解決辦法:
1)重啟資料庫。
2)重建表空間:
/**檢視當前的資料庫預設表空間**/
SQL>select * from database_properties where property_name='DEFAULT_TEMP_TABLESPACE';
/**確認當前的臨時表空間為TEMP**/
/**檢視目前臨時表空間的大小**/
SQL>select file_name,tablespace_name,bytes/1024/1024 "MB",autoextensible from dba_temp_files;
/**建立另一個臨時表空間**/
SQL>create temporary tablespace TEMP2 TEMPFILE 'D:\oradata\temp02.dbf' SIZE 10M REUSE AUTOEXTEND ON NEXT 1M MAXSIZE UNLIMITED;
/**改變預設臨時表空間為剛剛建立的新臨時表空間temp2**/
SQL>alter database default temporary tablespace temp2;
/**刪除原來臨時表空間**/
SQL>drop tablespace temp including contents and datafiles;
/**重新建立臨時表空間temp **/
SQL>create temporary tablespace TEMP TEMPFILE 'D:\oradata\temp01.dbf' SIZE 512M REUSE AUTOEXTEND ON NEXT 1M MAXSIZE UNLIMITED;
/**重置預設臨時表空間為新建的temp表空間**/
SQL>alter database default temporary tablespace temp;
/**刪除中轉用臨時表空間 **/
SQL>drop tablespace temp2 including contents and datafiles;
/**重新指定使用者表空間為重建的臨時表空間 **/
SQL>alter user yhm temporary tablespace temp;
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69994536/viewspace-2932045/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- ORACLE 臨時表空間使用率過高的原因及解決方案Oracle
- ORACLE臨時表空間使用率過高的原因及解決方法Oracle
- undo表空間使用率過高解決
- 臨時表空間過大的解決方法
- 【實驗】重建臨時表空間解決臨時表空間過大問題
- ORACLE 臨時表空間使用率過高分析Oracle
- oracle 表空間,臨時表空間使用率查詢Oracle
- 臨時表空間和回滾表空間使用率查詢
- oracle的臨時表空間使用率99.9%Oracle
- 轉:Oracle 臨時表空間過大問題解決Oracle
- 臨時表空間已滿的解決方法
- oracle11g 查詢臨時表空間的使用率和正在使用臨時表空間的使用者Oracle
- 【實驗】RESIZE方法解決臨時表空間過大問題
- ORACLE 臨時表空間滿了的原因解決方案Oracle
- 解決Oracle臨時表空間佔滿的問題Oracle
- oracle的臨時表空間解決問題的步驟Oracle
- oracle的臨時表空間Oracle
- 臨時表空間的建立、刪除,設定預設臨時表空間
- 臨時表空間資料檔案損壞的解決
- Jenkins臨時空間不足處理辦法Jenkins
- oracle 臨時表空間Oracle
- oracle臨時表空間Oracle
- Oracle臨時表空間檢視、新增臨時表空間資料檔案、修改預設臨時表空間 方法!Oracle
- 臨時表空間ORA-1652問題解決
- 【臨時表空間組】臨時表空間組的建立、維護及應用
- oracle臨時表空間過大的原因&&處理Oracle
- 批量處理時臨時增加回滾表空間臨時表空間檔案
- Oracle 臨時表空間的概念Oracle
- ORACLE臨時表空間的清理Oracle
- undo表空間太大解決辦法
- oracle 11g sysaux表空間使用率非常高的問題解決OracleUX
- mysql臨時表,臨時表空間,ibtmp1表空間暴增原因初探MySql
- Oracle 臨時表空間概念Oracle
- oracle臨時表空間組Oracle
- Oracle Temp 臨時表空間Oracle
- 【儲存管理】建立臨時表空間組、建立臨時表空間組及使用
- oracle 剩餘表空間查詢慢,解決辦法Oracle
- 【臨時表空間】11g中使用 SHRINK方法縮小臨時表空間和臨時檔案