Oracle日常問題-臨時表過多導致exp速度慢
Oracle日常問題
-臨時表過多導致
exp速度慢
問題現象:
客戶反饋資料庫日常備份速度越來越慢。
問題原因:
遠端檢視資料庫大小隻有5G ,備份卻需要 5 小時以上。
---5G
SQL> Select sum(bytes)/1024/1024/1024 from dba_segments where owner= ’ CJC ’ ;
在進行exp 備份時,先匯出建立表的語句,在匯出表資料,檢視備份日誌,還沒有匯出表資料就開始卡住了, 猜測表資料量不大,但是表數量很大 ,導致在 exp 一開始匯出建立表語句時卡住。
最終檢視到CJC 使用者下存在67 萬張臨時表;
S QL> select count(*) from user_tables where temporary='Y';
COUNT(*)
----------
673165
其中以 TEM_ 開頭的臨時表有62 萬張,以 TMPTABSUBJ% 開頭的有4 萬多張;
SQL> select count(*) from user_tables where temporary='Y' and table_name like'TEM_%';
COUNT(*)
----------
623866
SQL> select count(*) from user_tables where temporary='Y' and table_name like'TMPTABSUBJ%';
COUNT(*)
----------
47899
其中 TEM_ 開頭臨時表都是在09-14 年產生的,平均每天產生 1 萬張臨時表, 15-16 年沒有這種型別的臨時表;
SQL> select * from (select to_char(created,'yyyymmdd'),count(*)
2 from user_tables a,user_objects b
3 where a.table_name=b.object_name
4 and a.temporary='Y'
5 and a.table_name like'TEM_%'
6 group by to_char(created,'yyyymmdd')
7 order by 1 desc
8 )
9 where rownum<=1000;
TO_CHAR(CREATED,'YYYYMMDD') COUNT(*)
--------------------------- ----------
20140920 122
20140919 12207
20140918 11449
20140917 10951
20140916 15047
20140915 18865
......
69 rows selected
其中 TMPTABSUBJ 開頭臨時表都是在09-13 年產生的, 14-16 年沒有這種型別的臨時表;
SQL> select * from (
2 select to_char(created,'yyyymmdd'),count(*)
3 from user_tables a,user_objects b
4 where a.table_name=b.object_name
5 and a.temporary='Y'
6 and a.table_name like'TMPTABSUBJ%'
7 group by to_char(created,'yyyymmdd')
8 order by 1 desc
9 )
10 where rownum<=1000;
TO_CHAR(CREATED,'YYYYMMDD') COUNT(*)
--------------------------- ----------
20130930 109
20130929 133
20130928 13
......
30 rows selected
估計是應用程式使用完臨時後沒有及時自動刪除,導致臨時表資料量越來越多,在研發出補丁清理臨時表之前,可以先透過儲存過程,自動刪除幾天前的臨時表。
先備份使用者下所有表, 然後透過下面的儲存過程刪除5天前產生的 TEM_ 開頭和 TMPTABSUBJ% 開頭的臨時表;
--- 建立刪除臨時表的儲存過程
CREATE OR REPLACE PROCEDURE DROP_TEMPTAB AS
CURSOR a IS
select table_name
from user_tables c , user_objects d
where c.table_name = d.object_name
and c.temporary = 'Y'
and ( c.table_name like 'TEM_%' or c.table_name like 'TMPTABSUBJ%' )
and d.object_type = 'TABLE'
and d.temporary = 'Y'
and d.CREATED < sysdate - 5 ;
BEGIN
FOR i IN a LOOP
EXECUTE IMMEDIATE 'drop table ' || i.table_name ;
END LOOP ;
END ;
新增JOB ,定期執行該儲存過程,自動刪除臨時表, 每天 3 點執行 JOB ,每 2 天執行一次;
SQL> VARIABLE JOBNO NUMBER;
SQL> VARIABLE INSTNO NUMBER;
SQL>
SQL> BEGIN
2 SELECT INSTANCE_NUMBER INTO :INSTNO FROM V$INSTANCE;
3 DBMS_JOB.SUBMIT(:JOBNO,
4 'DROP_TEMPTAB; ',
5 TRUNC(SYSDATE) + 1 + 3 / 24,
6 'TRUNC(SYSDATE)+ 2 + 3 /24',
7 TRUE,
8 :INSTNO);
9 COMMIT;
10 END;
11 /
PL/SQL procedure successfully completed
檢視JOB 是否建立成功
SQL> select * from dba_jobs;
歡迎關注我的微信公眾號"IT小Chen",共同學習,共同成長!!!
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29785807/viewspace-2675881/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 27、oracle的臨時表問題Oracle
- 轉:Oracle 臨時表空間過大問題解決Oracle
- c++臨時物件導致的生命週期問題C++物件
- oracle 9i臨時表產生過多redoOracle
- 【實驗】重建臨時表空間解決臨時表空間過大問題
- dbms_lob儲存過程導致臨時表空間100%儲存過程
- oracle 9i 臨時表空間問題Oracle
- mysql臨時表的問題MySql
- 【YashanDB知識庫】EXP導致主機卡死問題
- Oracle監聽日誌過大導致的問題Oracle
- 解決:ORACLE 11G使用exp無法導空出表問題Oracle
- oracle臨時表Oracle
- Oracle 臨時表Oracle
- 解決Oracle臨時表空間佔滿的問題Oracle
- Oracle事務臨時表的一個隱藏問題Oracle
- ORACLE臨時表和SQLSERVER臨時表異同OracleSQLServer
- IBM HA雙機光交鏈路問題導致的oracle資料庫exp備份問題IBMOracle資料庫
- 故障分析 | MySQL 5.7 使用臨時表導致資料庫 CrashMySql資料庫
- oracle的臨時表空間解決問題的步驟Oracle
- Oracle的臨時表Oracle
- 【實驗】RESIZE方法解決臨時表空間過大問題
- 系統臨時表空間不足問題
- 高水位線下空閒塊過多導致的SQL效能問題SQL
- Oracle Temporary Tables(Oracle 臨時表)Oracle
- 時區問題導致時間相差8個小時
- oracle 臨時表的使用Oracle
- ORACLE臨時表總結Oracle
- Oracle全域性臨時表Oracle
- oracle 臨時表空間Oracle
- oracle臨時表空間Oracle
- oracle臨時表的用法Oracle
- 克隆ORACLE軟體的導致的問題Oracle
- mysql臨時表空間不夠導致主從複製失敗MySql
- 解決Oracle 11gR2 空閒連線過多,導致連線數滿的問題Oracle
- 臨時表空間資料刪除問題
- oracle臨時表空間過大的原因&&處理Oracle
- ORACLE 臨時表空間使用率過高分析Oracle
- SQL SERVER 臨時表導致儲存過程重編譯(recompile)的一些探討SQLServer儲存過程編譯Compile