从Oracle10g开始,Oracle引入了flashback drop的新特性,这个新特性,允许你从当前数据库中恢复一个被drop了的对象。在执行drop操作时,现在Oracle不是真正删除它,而是将该对象自动将放入回收站。对于一个对象的删除,其实仅仅就是简单的重令名操作。
所谓的回收站,是一个虚拟的容器,用于存放所有被删除的对象。在回收站中,被删除的对象将占用创建时的同样的空间,你甚至还可以对已经删除的表查询,也可以利用flashback功能来恢复它, 这个就是flashback drop功能。
这个功能虽然可以极大的简化误drop导致的恢复操作,但是长时间的积累可能会导致大量的空间占用(虽然Oracle具有自己的清理机制),很多时候我们需要手工介入去清理回收站。本文主要介绍清理回收站的几种方法.
1.大量累计的空间占用
Connected to Oracle Database 10g Enterprise Edition Release 10.1.0.3.0
OWNER OBJECT_NAME CREATETIME DROPTIME 750 rows selected SQL> |
2.不同用户在回收站的对象
SQL> select owner,count(*) from dba_recyclebin group by owner; OWNER COUNT(*) 6 rows selected. |
3.我们可以指定删除某些特定对象
SQL> purge table common.T_SERVICE_CODE_INFO; Table purged. |
4.指定清除某个表空间的所有回收站对象
SQL> purge tablespace common; Tablespace purged. SQL> select owner,count(*) from dba_recyclebin group by owner; OWNER COUNT(*) |
5.以SYSDBA身份可以清除所有回收站对象
SQL> purge dba_recyclebin; DBA Recyclebin purged. SQL> select owner,count(*) from dba_recyclebin group by owner; no rows selected |
6.禁用recyclebin