现在的位置: 首页 > 综合 > 正文

Oracle Flashback技术总结(二)—— Flashback DROP

2013年08月08日 ⁄ 综合 ⁄ 共 3616字 ⁄ 字号 评论关闭

二、Flashback DROP 

 

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

Flashback 不支持system表空间下的对象,不能从回收站里拿到。故使用SYS 或者SYSTEM用户登陆时, show recyclebin 为空。  

Flashback  table语法:

1. Flashback Drop 设置 

从Oracle 10g 开始, 每个表空间都会有一个叫作回收站的逻辑区域,当用户执行drop命令时, 被删除的表和表的关联对象( 包括索引, 约束,触发器,LOB段,LOB index 段) 不会被物理删除, 这些对象先转移到回收站中,这就给用户提供了一个恢复的可能。  

初始化参数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> alter system set recyclebin=off; (10g)

SQL> alter system set recyclebin=on;  (10g)

SQL>alter system set recyclebin=off deferred;  ( 11g  , deferred表示延时,需要重启以后生效)

SQL>alter system set recyclebin=on deferred;   (11g)

SQL> alter session set recyclebin=off; (10/11g)

SQL> alter session set recyclebin=on; (10/11g)

 

禁用后删除的对象将直接删除,不会写到Recycle中,当然在删除时,指定

purge 参数,表也将直接删除,不会写到recyclebin中。

          SQL> drop table name purge; 

 

查看recyclebin中的对象列表:

 

SQL> select * from A; 

        ID 

        ---------- 

         1 

         2 

         3 

SQL> drop table A; 

表已删除。 

SQL> show recyclebin 

ORIGINAL NAME    RECYCLEBIN NAME       OBJECT TYPE  DROP TIME 

----------------      -----------------------------          ------------       ------------------- 

 

A            BIN$RWXQQcTPRde0ws4h9ewJcg==$0  TABLE     2009-10-15:12:44:33 

 

查看recyclebin中对象:

 

SQL> select original_name,object_name from recyclebin; 

 

ORIGINAL_NAME                    OBJECT_NAME 

-------------------------------- ------------------------------ 

A                                BIN$RWXQQcTPRde0ws4h9ewJcg==$0 

 

查看recyblebin对象里的内容:

 

SQL> select * from "BIN$RWXQQcTPRde0ws4h9ewJcg==$0"; 

        ID

       ----------

         1

         2

         3

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

  • Purge tablespace tablespace_name : 用于清空表空间的Recycle Bin
  • urge tablespace tablespace_name user user_name: 清空指定表空间的Recycle Bin中指定用户的对象
  • Purge recyclebin: 删除当前用户的Recycle Bin中的对象
  • Purge dba_recyclebin: 删除所有用户的Recycle Bin中的对象,该命令要sysdba权限
  • Drop table table_name purge:  删除对象并且不放在Recycle Bin中,即永久的删除,不能用Flashback恢复。

6). Purge index recycle_bin_object_name: 当想释放Recycle bin的空间,又想能恢复表时,可以通过释放该对象的index所占用的空间来缓解空间压力。 因为索引是可以重建的。


2. Flashback Drop 实例操作

SYS@ orcl >select object_name,original_name from recyclebin;

OBJECT_NAME
       ORIGINAL_NAME

------------------------------ --------------------------------

BIN$3VLF0vGPjivgQAB/AQASgw==$0 TEST009


SYS@ orcl >flashback table test009 to before drop;

Flashback complete.

SYS@ orcl >select * from test009;

当我们删除表A后,在新建表A,这时在恢复的时候就会报错,此时我们在闪回时,对表重命名就可以了:

SYS@ orcl >flashback table test010 to before drop rename to test011;

当我们删除表A,在新建表A,在删除它,这是在Recycle Bin中就会有2个相同的表明,此时恢复我们就要指定object

_name才行.



SYS@ orcl >show recycle

ORIGINAL NAME
 RECYCLEBIN NAME OBJECT TYPE  DROP TIME

---------------- ------------------------------ ------------ -------------------

TEST011 
 BIN$3VLF0vGUjivgQAB/AQASgw==$0 TABLE
     2013-05-23:00:24:10

TEST011 
 BIN$3VLF0vGTjivgQAB/AQASgw==$0 TABLE
     2013-05-23:00:23:21

TEST011 
 BIN$3VLF0vGRjivgQAB/AQASgw==$0 TABLE
     2013-05-23:00:20:41

flashback table "BIN$3VLF0vGRjivgQAB/AQASgw==$0" to before drop


一旦完成闪回恢复,Recycle Bin中的对象就消失了. Flashback Drop 需要注意的地方:

  • 只能用于非系统表空间和本地管理的表空间
  • 对象的参考约束不会被恢复,指向该对象的外键约束需要重建。
  • 对象能否恢复成功,取决与对象空间是否被覆盖重用。
  • 当删除表时,信赖于该表的物化视图也会同时删除,但是由于物化视图并不会被放入recycle bin,因此当你执行flashback table to before drop 时,也不能恢复依赖其的物化视图,需要dba 手工介入重新创建。
  • 对于Recycle Bin中的对象,只支持查询.

抱歉!评论已关闭.