溫馨提示×

溫馨提示×

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

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

Oracle 手工清理臨時(shí)段

發(fā)布時(shí)間:2020-07-06 07:33:07 來源:網(wǎng)絡(luò) 閱讀:796 作者:hbxztc 欄目:關(guān)系型數(shù)據(jù)庫

  今天開發(fā)說一個(gè)測試庫里的表空間滿了需要清理,連上測試庫一看,確實(shí)已經(jīng)使用99.98%了。

TABLESPACE_NAME                SIZE_G          FREE_G          USED_PCT
------------------------------ --------------- --------------- ----------
E2TEST                               96.00            0.02    99.98%

  通過與開發(fā)溝通確定了刪除策略,先刪除了一些歷史表但是清理效果不大,直接通過DBA_SEGMENTS視圖查看ESOP2TEST表空間中bytes最大的表為E_CONT,占了28G。打算清理直接這張表。

OWNER                          SEGMENT_NAME       SUM(BYTES)/1024/1024
------------------------------ ------------------ --------------------
E2TEST                         E_CONT                  28983.3125

  開發(fā)要求保留最近一個(gè)月的數(shù)據(jù),所以打算建一張臨時(shí)表把最近一個(gè)月的數(shù)據(jù)導(dǎo)進(jìn)去,刪除原表,再把臨時(shí)表重命名為原表。過程其實(shí)很簡單,步驟也不復(fù)雜,但是在做完全部步驟后發(fā)現(xiàn)表空間使用率依然很高,清理沒有效果。

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居然變?yōu)榱藬?shù)字。。。

查看這個(gè)段的類型為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

在網(wǎng)上查資料,先看到惜分飛的一篇blog,介紹type為TEMPORARY,name為file#.block#對象重現(xiàn)和清理

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

跟他里邊描述的不太一樣,按他寫的方法無法進(jìn)行清理。

繼續(xù)查發(fā)現(xiàn)一篇文章介紹的情況跟我的比較相似,http://blog.chinaunix.net/uid-22948773-id-3758510.html

重啟數(shù)據(jù)庫或用下面的方法清理:

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段已經(jīng)沒有了,表空間也徹底被釋放了

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%



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

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

AI