oracle drop table 闪回恢复


Flashback Drop 是从Oracle 10g 开始出现的,用于恢复用户误删除的对象(包括表,索引等),这个技术依赖于Tablespace Recycle Bin(表空间回收站)。


注意:Flashback不支持sys用户、system表空间下的对象;

一、recyclebin的相关参数和说明

1. 初始化参数 recyclebin 用于控制是否启用recyclebin功能,默认状态是开启ON,可以用OFF关闭。

SQL> show parameter recycle

NAME                    TYPE           VALUE
----------------------------------------------
buffer_pool_recycle     string
db_recycle_cache_size  big integer      0
recyclebin             string           on
SQL> 

 
2.开启和关闭该功能:
SQL> alter system set recyclebin=off;
SQL> alter system set recyclebin=on;

禁用回收站后删除的对象将直接删除,不会写到Recycle中,
在删除时指定purge 参数,表也将直接删除不会写到recyclebin中。
例: drop table t1 purge; 不会写到recyclebin中


表空间的Recycle Bin 区域只是一个逻辑区域,而不是从表空间上物理的划出一块区域固定用于回收站,
因此Recycle Bin是和普通对象共用表空间的存储区域,或者说是Recycle Bin的对象要和普通对象抢夺存储空间。
当发生空间不够时,Oracle会按照先入先出的顺序覆盖Recycle Bin中的对象。也可以手动的删除Recycle Bin占用的空间。

3清空回收站:
<1>. purge tablespace tablespace_name : 用于清空表空间的Recycle Bin.
<2>. purge tablespace tablespace_name user user_name: 清空指定表空间的Recycle Bin中指定用户的对象.
<2>. purge recyclebin                 : 删除当前用户的Recycle Bin中的对象.
<4>. purge dba_recyclebin             : 删除所有用户的Recycle Bin中的对象,该命令要sysdba权限.
<5>. drop table table_name purge      : 删除对象并且不放在Recycle Bin中,即永久的删除,不能用Flashback恢复.

二、drop表进行恢复

1. 连接sqlplus 创建一个表

SQL> conn zw/zw
Connected.

QL> create table t12 as select * from user_objects;

Table created.

SQL> select count(*) from t12;

  COUNT(*)
----------
    1

2.删除t12表

SQL> drop table t12;

Table dropped.

SQL> select count(*) from t12;
select count(*) from t12
                     *
ERROR at line 1:
ORA-00942: table or view does not exist
可以看到表t12已经被删除


3.查看recyclebin的信息

SQL> col origninal_name format a15;
SQL> col type format a15;
SQL> select object_name,original_name,type from user_recyclebin;

OBJECT_NAME   ORIGINAL_NAME TYPE
----------------------------------------------------------------------
BIN$KswP8LfMaBjgUww4qMC6Tw==$0      ZW TABLE
BIN$Kswyt5BhaDLgUww4qMDxsg==$0 T12    TABLE
可以看到T12就是刚才被删除的表

4.闪回删除的表

SQL> flashback table t12 to before drop;

Flashback complete.

SQL> select count(*) from t12;

  COUNT(*)
----------
      1

可以看到表t12已经被恢复

如果出现这样的情况:表t1删除后,一个同名的对象t1被创建,闪回的时候需要重新命名
flashback table t1 to before drop rename to t2;

还有一种情况:同名的表被多次drop到了recyclebin中,这时候遵循后进先出的原则.

5.一旦完成闪回恢复,Recycle Bin中的对象就消失了.

SQL> select object_name,original_name,type from user_recyclebin;

OBJECT_NAME     ORIGINAL_NAME   TYPE
---------------------------------------------------------------------------------
BIN$KswP8LfMaBjgUww4qMC6Tw==$0 ZW      TABLE

可以看到t12在回收站已经不见了
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值