开启、关闭回收站
首先你可以通过命令查看数据库是否开启了回收站机制, 如下所示 VALUE= ON表示开启了回收站机制。OFF则表示回收站机制关闭。
SHOW PARAMETER RECYCLEBIN;
SELECT NAME, VALUE FROM V$PARAMETER WHERE NAME='recyclebin';
可以通过设置初始化参数recyclebin启用或禁用回收站功能。当然也可以用命令关闭回收站
ALTER SYSTEM SET RECYCLEBIN=OFF;
ERROR at line 1:
ORA-02096: specified initialization parameter is not modifiable with this option
ALTER SESSION SET RECYCLEBIN=OFF;
可以用命令开启回收站
ALTER SYSTEM SET RECYCLEBIN=ON;
ERROR at line 1:
ORA-02096: specified initialization parameter is not modifiable with this option
ALTER SESSION SET RECYCLEBIN =ON;
查看回收站对象
我们先来看看一个例子,如下所示,假如不小心误操作DROP了表test,那么我们如何在回收站查看被DROP的表对象呢?
conn nick/nick
create table test(name varchar2(16));
insert into test select 'kkkkk' from dual;
insert into test select 'hhhhh' from dual;
commit;
drop table test;
show recyclebin;
SQL 2: 其中RECYCLEBIN是USER_RECYCLEBIN 的同义词。
col object_name for a30
col original_name for a8
col operation for a9
col type for a8
col droptime for a19
col ts_name for a30
select object_name,original_name,operation,type,droptime,ts_name from recyclebin;
--查看数据库当前用户的回收站对象
SELECT * FROM USER_RECYCLEBIN;
--查看数据库回收站所有对象
SELECT * FROM DBA_RECYCLEBIN;
为了避免被删除的表与同类对象名称的重复,被删除的表以及相依的对象放到回收站后,ORACLE数据库会对被删除的对象名称进行重命名,例如表TEST表
show recyclebin
ORIGINAL NAME RECYCLEBIN NAME OBJECT TYPE DROP TIME
---------------- ------------------------------ ------------ -------------------
TEST BIN$5SmI2O8cLlrgUzQBqMBPFQ==$0 TABLE 2022-08-01:14:59:00
我们又创建了表TEST,然后删除了该表TEST,如下所示,虽然ORIGINAL_NAME一致,但是RECYCLEBIN NAME则有所不同。
create table test(name varchar2(16));
drop table test;
show recyclebin
ORIGINAL NAME RECYCLEBIN NAME OBJECT TYPE DROP TIME
---------------- ------------------------------ ------------ -------------------
TEST BIN$5SmI2O8dLlrgUzQBqMBPFQ==$0 TABLE 2022-08-01:15:08:43
TEST BIN$5SmI2O8cLlrgUzQBqMBPFQ==$0 TABLE 2022-08-01:14:59:00
select * from "BIN$5SmI2O8cLlrgUzQBqMBPFQ==$0";
还原回收站对象
还原回收站被删除的表、索引等对象, 是通过Flashback Drop实现的。
FLASHBACK TABLE TEST TO BEFORE DROP;
但是如果出现上面两个TEST表都被删除时
show recyclebin
ORIGINAL NAME RECYCLEBIN NAME OBJECT TYPE DROP TIME
---------------- ------------------------------ ------------ -------------------
TEST BIN$5SmI2O8dLlrgUzQBqMBPFQ==$0 TABLE 2022-08-01:15:08:43
TEST BIN$5SmI2O8cLlrgUzQBqMBPFQ==$0 TABLE 2022-08-01:14:59:00
flashback table test to before drop;
show recyclebin
ORIGINAL NAME RECYCLEBIN NAME OBJECT TYPE DROP TIME
---------------- ------------------------------ ------------ -------------------
TEST BIN$5SmI2O8cLlrgUzQBqMBPFQ==$0 TABLE 2022-08-01:14:59:00
select * from test;
no rows selected
如上所示,如果两个相同名字的表TEST被删除了,此时闪回被DROP的表TEST,实质是闪回最后一个被删除的表(后进先出原则),如果此时继续闪回操作就会报ORA-38312错误
flashback table test to before drop;
*
ERROR at line 1:
ORA-38312: original name is used by an existing object
此时可以在闪回过程中对表名进行重命名解决问题。
flashback table test to before drop rename to test_2;
select * from test_2;
另外,如果回收站有两个被DROP掉的表TEST, 如果想闪回第一个被删除的表,那该怎么办呢?
show recyclebin
ORIGINAL NAME RECYCLEBIN NAME OBJECT TYPE DROP TIME
---------------- ------------------------------ ------------ -------------------
TEST BIN$5SmI2O8fLlrgUzQBqMBPFQ==$0 TABLE 2022-08-01:15:20:31
TEST BIN$5SmI2O8eLlrgUzQBqMBPFQ==$0 TABLE 2022-08-01:15:20:20
直接指定RECYCLEBIN NAME进行闪回即可。
flashback table "BIN$5SmI2O8eLlrgUzQBqMBPFQ==$0" to before drop;
清空回收站
数据库对象删除后,数据库会把它重命名为BIN$开头的对象,你可以通过ORIGINAL_NAME查看它对应的原始对象名称。记住,将表放在回收站里并不在原始表空间中释放空间。如果您希望完全删除该表,而不让该表放入回收站,可以使用以下命令永久删除该表。当然这样操作后,你也不能通过使用闪回特性闪回该表了。
DROP TABLE TABLE_NAME PURGE;
如果数据库中删除表时都放入回收站,因而没有释放所占空间,那么当空闲的空间不足时,已经删除的表是否还会侵占存储空间呢?
★答案很简单:当表空间被回收站数据完全占满,以至于必须扩展数据文件来容纳更多数据时,可以说表空间处于“空间压力”情况下。此时,对象以先进先出的方式从回收站中自动清除。在删除表之前,相关对象(如索引)被删除。
★同样,空间压力可能由特定表空间定义的用户限额而引起。表空间可能有足够的空余空间,但用户可能将其在该表空间中所分配的部分用完了。在这种情况下,Oracle 自动清除该表空间中属于该用户的对象。
此外,有几种方法可以手动控制回收站。如果在删除名为 TEST 的特定表之后需要从回收站中清除它,可以执行
PURGE TABLE TABLE_NAME;
或者使用其回收站中的名称:
PURGE TABLE "BIN$04LhcpndanfgMAAAAAANPw==$0";
此命令将从回收站中删除表 TEST 及所有相关对象,如索引、约束等,从而节省了空间。但是,如果要从回收站中永久删除索引,则可以使用以下命令来完成工作:
PURGE INDEX IN_TEST1_O1;
此命令将仅仅删除索引,而将表的拷贝留在回收站中。有时在更高级别上进行清除可能会有用。例如,您可能希望清除表空间 USERS 的回收站中的所有对象。可以执行:
PURGE TABLESPACE USERS;
您也许希望只为该表空间中特定用户清空回收站。在数据仓库类型的环境中,用户创建和删除许多临时表,此时这种方法可能会有用。您可以更改上述命令,限定只清除特定的用户:
PURGE TABLESPACE USERS USER SCOTT;
要释放整个回收站占用的空间,您需要使用以下命令清空回收站:
PURGE RECYCLEBIN;
记住PURGE RECYCLEBIN只是清除当前用户在回收站中的对象,DBA_RECYCLEBIN下的对象并没有删除,如果你要清除当前数据库回收站的对象,必须使用下面命令(DBA权限)
PURGE DBA_RECYCLEBIN
Flashback Drop注意事项
1:只能用于非系统表空间和本地管理的表空间。
如下所示,在系统表空间中,表对象删除后就真的从系统中删除了,而不是存放在回收站中。
show user
USER is "SYS"
create table test(name varchar2(12));
drop table test;
show recyclebin;
2:对象的参考约束不会被恢复,指向该对象的外键约束需要重建。
3:对象能否恢复成功,取决于对象空间是否被覆盖重用。
4:当删除表时,依赖于该表的物化视图也会同时删除,但是由于物化视图并不会放入recycle binzhong,因此当你执行flashback drop时,并不能恢复依赖其的物化视图。需要DBA手工重建。
5:对于回收站(Recycle Bin)中的对象,只支持查询。不支持任何其他DML、DDL等操作。
select * from "BIN$5SpIyEdlOTXgUzQBqMClGg==$0";




