oracle 9i以前,当drop一个表时,到该表的所有引用都会从数据字典中删除。
oracle 10g及以后,当drop一个表时,数据库根本没有删除表,而只是重命名了并放入了回收站。即当发出drop命令时,其实数据库内部执行的是rename操作,此操作应用于index, trigger, constraint,forgein key除外。
既然是rename,就可以撤消删除——通过将表重命名为它原先的名称。但并不能保证总是成功的。因为表占用的空间可能被重用,或在此期间创建了另一个表,表名与被删除的表名相同。

本实验创建一个新的模式tough,并在该模式内创建一个表t,然后drop。之后使用flashback drop恢复它。

SQL> create user tough identified by tough;
SQL> grant create session, resource to tough;

//接下来以新创建的用户tough登录

SQL> create table t (id number, name varchar2(10));
SQL> create index t_idx on t(id);
SQL> alter table t add constraint t_uk unique(id);

SQL> insert into t values (1,'Tough1');
SQL> insert into t values (2,'Tough1');
SQL> commit;

//查看所创建的对象

SQL> select object_name, object_type from user_objects;
OBJECT_NAME               OBJECT_TYPE
------------------------- -------------------
T                         TABLE
T_IDX                     INDEX

//查看所创建的约束

SQL> select constraint_name, constraint_type, table_name from user_constraints;
CONSTRAINT_NAME CONSTRAINT_TYPE TABLE_NAME
------------------  ---------------   ------------
T_UK               U               T

SQL> drop table t;

//删除表后,表上的index,constraint也被删除。被删除的对象以新的名称放到了回收站中

SQL> select object_name,original_name,type from user_recyclebin;
OBJECT_NAME                    ORIGINAL_NAME                    TYPE
------------------------------ -------------------------------- -------
BIN$UXcOdSu3ROWVOHPk8Dpp+Q==$0 T                                TABLE
BIN$bhFm5rD3Q8ajZdpMhbXdMQ==$0 T_IDX                            INDEX

//此时仍然可以对drop掉的表t作查询,但需使用回收站中的表名

SQL> select * from "BIN$UXcOdSu3ROWVOHPk8Dpp+Q==$0";
        ID NAME
---------- ----------
         1 Tough1
         2 Tough1

//但无法对回收站中的对象执行 DDL/DML

SQL> insert into "BIN$UXcOdSu3ROWVOHPk8Dpp+Q==$0" values (1,'Tough');
insert into "BIN$UXcOdSu3ROWVOHPk8Dpp+Q==$0" values (1,'Tough')
ORA-38301: 无法对回收站中的对象执行 DDL/DML

//执行flashback table恢复删除掉的表

SQL> flashback table t to before drop;

或使用下面的方式作恢复

//这样做是有必要的,可以防止闪回期间创建了另一个与删除表重名的表

SQL> flashback table t to before drop rename to t_new;

//恢复后可以查看对象,但发现index,constraint使用的还是回收站中的名字

SQL> select object_name, object_type from user_objects;
OBJECT_NAME                        OBJECT_TYPE
---------------------------------- -----------
T                                  TABLE
BIN$bhFm5rD3Q8ajZdpMhbXdMQ==$0     INDEX

SQL> select constraint_name, constraint_type, table_name from user_constraints;
CONSTRAINT_NAME                CONSTRAINT_TYPE TABLE_NAME
------------------------------ --------------- ---------
BIN$L6IXINvgSs6FAWa2FNiVYw==$0 U               T

//我们可以对index,constraint重命名

SQL> alter index "BIN$bhFm5rD3Q8ajZdpMhbXdMQ==$0" rename to T_IDX;
SQL> alter table t rename constraint "BIN$L6IXINvgSs6FAWa2FNiVYw==$0" to T_UK;

//重命名后一切ok

SQL> select object_name, object_type from user_objects;
OBJECT_NAME               OBJECT_TYPE
------------------------- -------------------
T                         TABLE
T_IDX                     INDEX

SQL> select constraint_name, constraint_type, table_name from user_constraints;
CONSTRAINT_NAME    CONSTRAINT_TYPE TABLE_NAME
------------------ --------------- ------------
T_UK               U               T

//查询之前删除的表t,数据都恢复回来了

SQL> select * from t;
        ID NAME
---------- ----------
         1 Tough1
         2 Tough1

实验完毕。

关于闪回表,需要注意以下几点:
1. flashback drop只能执行drop命令后的恢复,而不能恢复truncate命令;
2. 如果删除了一个用户,不能闪回任何表。因为将模式删除,oracle无法维护对象(即使在回收站内),因为没有可供连接的用户;
3. 所有闪回操作出现在对象所属模式内;
4. 如果删除了表,然后创建了同名的表,接着删除了它。那么在回收站内将有两个表。它们具有不同的回收站名称,但原始名相同。默认情况下flashback drop总是闪回最新版本的表。若最新的表不是你想要的版本,你可以指定你希望恢复的版本的回收站名称,而不是原先的表名。
flashback "BIN$UXcOdSu3ROWVOHPk8Dpp+Q==$0" to before drop;
5. flashback不适用于system表空间;


Flashback删除(闪回删除)的更多相关文章

  1. oracle recyclebin详解(闪回删除的表)

    今天在SOA应用数据库上运用DBMS_REDEFITION包进行在线非分区表转换分区表操作时,本想DROP掉建的临时表cube_scope_temp不小心后面忘记加"temp"直接 ...

  2. Oracle Flashback Technologies - 闪回被drop的表

    Oracle Flashback Technologies - 闪回被drop的表 在oracle10g中,drop一个表后,表没有真正被删除,支持被rename后放在recyclebin中. #新建 ...

  3. Oracle Flashback Technologies - 闪回查询

    Oracle Flashback Technologies - 闪回查询 查看表中,某行数据的修改记录 #创建一个表,并插入和修改数据 SQL> create table y3(id )); T ...

  4. Oracle Flashback Technologies - 闪回数据库

    Oracle Flashback Technologies - 闪回数据库 根据指定的SCN,使用rman闪回数据库 #查看可以闪回到多久前 SQL> select * from v$flash ...

  5. flashback query闪回数据

    误删除了部分重要数据,已提交,需要恢复.首先尝试flashback query闪回数据. 数据库运行在归档模式,首先确认数据库的SCN的变化: SQL> col fscn for 9999999 ...

  6. PLSQL_闪回删除FlashBack Delete表误删除如何进行恢复(案例)

    2014-07-02 Created By BaoXinjian

  7. PLSQL_闪回删除FlashBack Drop表误删除如何进行恢复(案例)

    2014-06-25 Created By BaoXinjian

  8. oracle数据库flashback系列--闪回数据库在dataguard中的使用

    很多人在学习flashback database这个oracle技术的时候,都会有一个疑问,就是如果我只有一个数据库作为生产库的话,是否有这样的业务需求导致我们要把数据库闪回到以前的时间点?以及这样做 ...

  9. Flashback Database 闪回数据库

    一.  Flashback Database 说明 Flashback Database 功能非常类似与 RMAN 的不完全恢复, 它可以把整个数据库回退到过去的某个时点的状态, 这个功能依赖于 Fl ...

随机推荐

  1. WdatePicker时间控件联动选择

    $("#txtStartTime").bind("click focus", function () { var endtimeTf = $dp.$('txtE ...

  2. CentOS(四)--Linux系统的启动级别

    对于绝大多数Linux程序员来说,进入Linux系统后一般看到的是黑乎乎的界面(开发模式),因为系统如果启动选择开发模式,会减少启动时间,优化内存等.但是通常我们刚安装完Linux系统,然后进去以后是 ...

  3. 给jdk写注释系列之jdk1.6容器(10)-Stack&Vector源码解析

    前面我们已经接触过几种数据结构了,有数组.链表.Hash表.红黑树(二叉查询树),今天再来看另外一种数据结构:栈.      什么是栈呢,我就不找它具体的定义了,直接举个例子,栈就相当于一个很窄的木桶 ...

  4. 转: android studio 消除SDK更新时的“https://dl-ssl.google.com refused”错误

    消除了: hostname in certificate didn't match: 转: http://blog.csdn.net/gaojinshan/article/details/987160 ...

  5. oracle数据库创建表空间和表临时空间

    1:创建临时表空间 create temporary tablespace user_temp tempfile 'Q:\oracle\product\10.2.0\oradata\Test\xyrj ...

  6. 给 Android 初学者的 Gradle 知识普及

    给 Android 初学者的 Gradle 知识普及:http://gold.xitu.io/entry/5778f8bd165abd0054b443b0/promote?utm_source=bai ...

  7. C# @符号的多种使用方法

    1.限定字符串用 @ 符号加在字符串前面表示其中的转义字符“不”被处理.如果我们写一个文件的路径,例如"D:/文本文件"路径下的text.txt文件,不加@符号的话写法如下:str ...

  8. NodeJS服务器退出:完成任务,优雅退出

    上一篇文章,我们通过一个简单的例子,学习了NodeJS中对客户端的请求(request)对象的解析和处理,整个文件共享的功能已经完成.但是,纵观整个过程,还有两个地方明显需要改进: 首先,不能共享完毕 ...

  9. Linux小白最佳实践:《超容易的Linux系统管理入门书》(连载五)Linux系统的对话方式

    本篇是Linux小白最佳实践第5篇,目的就是让白菜们了解Linux进程之间是如何对话的.之前连载的几篇,在微信上引起了很多的反响,有人也反映图多文字少,感觉没有干货.本篇选了大部分是实战讲解的&quo ...

  10. Java-IO 输入输出流详解

    一.文件的编码               开发时一定要注意项目默认的编码!!!!!!!!               文件操作的时候一定要记得关闭!!!!!!!!        ASCII:美国标准 ...