您好,登錄后才能下訂單哦!
今天開發說一個測試庫里的表空間滿了需要清理,連上測試庫一看,確實已經使用99.98%了。
TABLESPACE_NAME SIZE_G FREE_G USED_PCT ------------------------------ --------------- --------------- ---------- E2TEST 96.00 0.02 99.98%
通過與開發溝通確定了刪除策略,先刪除了一些歷史表但是清理效果不大,直接通過DBA_SEGMENTS視圖查看ESOP2TEST表空間中bytes最大的表為E_CONT,占了28G。打算清理直接這張表。
OWNER SEGMENT_NAME SUM(BYTES)/1024/1024 ------------------------------ ------------------ -------------------- E2TEST E_CONT 28983.3125
開發要求保留最近一個月的數據,所以打算建一張臨時表把最近一個月的數據導進去,刪除原表,再把臨時表重命名為原表。過程其實很簡單,步驟也不復雜,但是在做完全部步驟后發現表空間使用率依然很高,清理沒有效果。
TABLESPACE_NAME SIZE_G FREE_G USED_PCT ------------------------------ --------------- --------------- ---------- E2TEST 96.00 0.89 99.07%
再次查看通過DBA_SEGMENTS查看空間占用情況。
SQL> select * from (select owner,segment_name,sum(bytes)/1024/1024 from dba_segments where tablespace_name='E2TEST' group by owner,segment_name order by 3 desc ) where rownum < 50; OWNER SEGMENT_NAME SUM(BYTES)/1024/1024 ------------------------------ ------------------------------ -------------------- E2TEST 20.962 28981
segment_name居然變為了數字。。。
查看這個段的類型為TEMPORARY
SQL> select * from (select owner,segment_name,segment_type,sum(bytes)/1024/1024 from dba_segments where tablespace_name='E2TEST' group by owner,segment_name,segment_type order by 4 desc ) where rownum < 50; OWNER SEGMENT_NAME SEGMENT_TYPE SUM(BYTES)/1024/1024 ------------------------------ ------------------------------ ------------------ -------------------- E2TEST 20.962 TEMPORARY 28981
在網上查資料,先看到惜分飛的一篇blog,介紹type為TEMPORARY,name為file#.block#對象重現和清理
http://www.xifenfei.com/2015/12/type%E4%B8%BAtemporaryname%E4%B8%BAfile-block%E5%AF%B9%E8%B1%A1%E9%87%8D%E7%8E%B0%E5%92%8C%E6%B8%85%E7%90%86.html
跟他里邊描述的不太一樣,按他寫的方法無法進行清理。
繼續查發現一篇文章介紹的情況跟我的比較相似,http://blog.chinaunix.net/uid-22948773-id-3758510.html
重啟數據庫或用下面的方法清理:
alter session set events 'immediate trace name DROP_SEGMENTS level TS#+1';
level - tablespace number+1. If the value is 2147483647 then
temp segments in ALL tablespaces are dropped, otherwise, only
segments in a tablespace whose number is equal to the LEVEL
specification are dropped.
1、查詢所在表空間的編號
SQL> select ts# from v$tablespace where name='E2TEST'; TS# ---------- 5
2、使用上述方法清理
SQL> alter session set events 'immediate trace name DROP_SEGMENTS level 6'; Session altered.
3、再次查看最大的TEMPORY段已經沒有了,表空間也徹底被釋放了
SQL> select * from (select owner,segment_name,segment_type,sum(bytes)/1024/1024 from dba_segments where tablespace_name='E2TEST' group by owner,segment_name,segment_type order by 4 desc ) where rownum < 50; OWNER SEGMENT_NAME SEGMENT_TYPE SUM(BYTES)/1024/1024 ------------------------------ --------------------------------------------------------------------------------- ------------------ -------------------- E2TEST T_CONT TABLE 12332 E2TEST SYS_LOB0000017851C00008$$ LOBSEGMENT 9834 E2TEST ERMSGLOG TABLE 5974 TABLESPACE_NAME SIZE_G FREE_G USED_PCT ------------------------------ --------------- --------------- ---------- E2TEST 96.00 31.68 67.00%
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。