刪除Oracle 10g垃圾表的好方法

tolywang發表於2008-02-01
經常使用oracle10g,我們可以發現以前刪除的表在資料庫中出現了特別多的垃圾表,如下例:

  BINjR8PK5HhrrgMK8KmgQ9nw==

  這一類的表通常無法刪除,並且無法用"delete"刪除,這種情況的出現,
[@more@]



  一般不會影響正常的使用,但是有遇到以下幾種情況時則必須刪掉它。

  1.這些表佔用空間

  2.如果使用Middlegen-Hibernate-r5的朋友會發現一些問題,不你象以前用oracle9時那麼順的生成hibernate配置檔案,原因就在這裡將它刪除就沒有問題了.

  3.其它情況

  BINjR8PK5HhrrgMK8KmgQ9nw==

  這一類的表是是10g 的新特性。

  Drop Table 後,沒有真正的刪除表,而是在“垃圾站”中了。可以透過下面看到。

  SQL> SHOW RECYCLEBIN

  如果要徹底刪除,可以使用:

  SQL> PURGE TABLE "BINjR8PK5HhrrgMK8KmgQ9nw==";

  刪除這一個或刪除全部。

  SQL> PURGE RECYCLEBIN ;

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/35489/viewspace-998997/,如需轉載,請註明出處,否則將追究法律責任。

相關文章