`

闪回删除(Flashback drop)

阅读更多

大家在平时开发中,有时意外的删除过表,可能就是直接重新创建该表。在oracle10g中,可以用Flashback drop恢复用一个被删除(drop)了的对象,oracle自动将该对象放入回收站。Flashback drop恢复的原理也是利用oracle的回收站来恢复被删除(drop)的对象。

回收站,是一个虚拟的容器,用于存放所有被删除的对象。其实,对于一个对象的删除,数据库仅仅是简单的重命名操作。

数据库参数recyclebin设置为on.(即默认设置)。参数recyclebin为on,则表示把Drop的对象放入回收站。为off,则表示直接删除对象而不放入回收站。

查看recyclebin值命令如:

SQL> show parameter bin;

NAME                         TYPE       VALUE

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

recyclebin                        string     on

在系统或会话级别中修改参数recyclebin值的命令为:

SQL>alter system set recyclebin = on|off;

SQL>alter session set recyclebin = on|off;

查看回收站的相关信息视图有:recyclebin/user_recyclebin/dba_recyclebin.

手动清除回收站的信息为:purge recyclebin(或purge table original_name);

删除一张表而不想放入回收站的命令为:drop table table_name purge;

示例1:

1.查看用户下回收站的信息,此时回收站为空

SQL>selectOBJECT_NAME,ORIGINAL_NAME,TYPEfromuser_recyclebin;
OBJECT_NAME                   ORIGINAL_NAME TYPE           
------------------------------ ------------- ------
2.
创建测试表tab_test,并为该表增加ind_test索引
SQL>createtabletab_testasselect*fromall_objects;
Tablecreated
SQL>createindexind_testontab_test(object_id);
Indexcreated

SQL> select count(*) from tab_test;

 COUNT(*)

----------

    40699
3
。用drop命令删除tab_test表
SQL>droptabletab_test;

Tabledropped
4。查看用户回收站信息,此时会记录删除后的对象在回收站中的相关信息,此时还能正常操作回收站中的对象,但不能操作DDL/DML语句
SQL>selectOBJECT_NAME,ORIGINAL_NAME,TYPEfromuser_recyclebin;

OBJECT_NAME                   ORIGINAL_NAME TYPE           
------------------------------ ------------- ------
BIN$a+iPOcq+QXiwUT8B3c3QoA==$0 IND_TEST      INDEX                    
BIN$zFJjV8zFSlqbLecXbDeANQ==$0 TAB_TEST      TABLE                   

SQL>selectcount(*)from"BIN$zFJjV8zFSlqbLecXbDeANQ==$0";

 COUNT(*)
----------
    
40699

SQL>deletefrom"BIN$zFJjV8zFSlqbLecXbDeANQ==$0";

deletefrom"BIN$zFJjV8zFSlqbLecXbDeANQ==$0"
ORA-
38301:无法对回收站中的对象执行DDL/DML

5.用flashback恢复表到删除之前的状态
SQL>flashbacktabletab_testtobeforedrop;
Done

SQL> select count(*) from tab_test;

 COUNT(*)

----------

    40699

6.恢复表的索引(此时表中的索引同时也被恢复了,只不过该索引还是保留回收站中的索引名称)

SQL> select index_name from user_indexes where table_name = 'TAB_TEST';

INDEX_NAME

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

BIN$a+iPOcq+QXiwUT8B3c3QoA==$0

SQL> alter index "BIN$a+iPOcq+QXiwUT8B3c3QoA==$0" rename to ind_test;

Index altered

SQL> select index_name from user_indexes where table_name = 'TAB_TEST';

INDEX_NAME

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

IND_TEST

示例2:

1.查看用户下回收站的信息,此时回收站为空

SQL>selectOBJECT_NAME,ORIGINAL_NAME,TYPEfromuser_recyclebin;
OBJECT_NAME                   ORIGINAL_NAME TYPE           
------------------------------ ------------- ------
2.
创建测试表test1,并输入数据
SQL> create table test1(id number);

Table created

SQL> insert into test1 values(1);

1 row inserted

SQL> insert into test1 values(2);

1 row inserted

SQL> insert into test1 values(3);

1 row inserted

SQL> insert into test1 values(4);

1 row inserted

SQL> commit;

Commit complete

SQL> select count(*) from test1;

 COUNT(*)

----------

        4

3.删除test1表,然后在重新创建test1表

SQL> drop table test1;

Table dropped

SQL> create table test1(id number);

Table created

SQL> insert into test1 values(1);

1 row inserted

SQL> commit;

Commit complete

SQL> select count(*) from test1;

 COUNT(*)

----------

        1

4.再次删除test1表

SQL> drop table test1;

Table dropped

5.查询回收站信息(此时回收站中有两条test1表的数据)

SQL>select*fromuser_recyclebin;

OBJECT_NAME                   ORIGINAL_NAME  TYPE                     
------------------------------ --------------------
BIN$Uk69X077TQWqQ0OQ3u1FdQ==$0 TEST1         TABLE                   
BIN$kpG5ZWdlRUi/jO6X0EYP+A==$0 TEST1         TABLE 

5.用flashback恢复表到删除之前的状态

SQL> flashback table test1 to before drop;

Done

SQL> select count(*) from test1;

 COUNT(*)

----------

        1

此时查看恢复后的test1,发现恢复到最近一次的信息,因此可说明多次删除后,在回收站中会存在多条与test1有关的数据,而用flashback table test1 to before drop命令恢复到的是test1表中最近一次删除的信息


分享到:
评论

相关推荐

    Oracle 闪回特性 FLASHBACK & RECYCLEBIN

    Oracle 闪回特性 FLASHBACK & RECYCLEBIN Flashback 系列是 Oracle 数据库中的一组功能强大且实用的闪回机制,旨在帮助数据库管理员和开发者快速恢复数据库中的各种对象,包括表、数据、事务等。Flashback 系列的...

    Oracle闪回(Flashback)技术.pptx

    2. 闪回丢弃(Flashback Drop):类似于操作系统的垃圾回收站功能,可以从中恢复被drop的表或索引。该功能基于撤销数据。 3. 闪回查询(Flashback Query):查询过去某个时间点或者某个 SCN 值时表中的数据信息。 4....

    BLOG_Oracle 回收站及flashback drop_LHR.pdf

    flashback drop是指Oracle提供的闪回技术中的一种,它允许用户通过闪回查询功能将被删除的对象从回收站中恢复。这个功能使得在误删除对象后能够迅速而准确地恢复数据,缩短了数据恢复的时间,减少了数据丢失的风险...

    oracle 闪回 flashback

    Oracle 10g引入了多种闪回功能,包括Flashback Database、Flashback Drop、Flashback Query以及Flashback Table。 1. **Flashback Database**: - Flashback Database允许用户将整个数据库恢复到过去的一个特定...

    第16章Oracle闪回(Flashback)技术.pptx

    7. **闪回丢弃(Flashback Drop)**:类似于操作系统中的“回收站”,被DROP的表或索引可以在闪回丢弃中找回,前提是撤销数据未被清除。 在使用闪回技术时,需要确保有足够的存储空间来保存闪回日志,并且要合理...

    flashback闪回技术

    ### Flashback闪回技术 #### 一、概述 Flashback技术是Oracle数据库中一项重要的数据恢复工具,它基于Undo Segment中的内容实现,并受到UNDO_RETENTION参数的影响。要使用这项特性,用户必须启用自动撤销管理表...

    Oracle_FlashBack闪回技术

    2. **使用闪回功能**:通过`FLASHBACK TABLE table_name TO BEFORE DROP;`命令恢复已删除的表。 #### 五、闪回表数据的修改 对于表中的数据被意外修改或删除的情况,可以使用以下方法恢复: 1. **闪回查询**:使用...

    Oracle 误删除后的闪回方法

    3. **闪回删除(Flashback Drop)** 如果不小心删除了表,可以使用`FLASHBACK TABLE`配合`RENAME`来恢复。例如: ```sql FLASHBACK TABLE deleted_table TO BEFORE DROP; RENAME deleted_table TO original_...

    oracel闪回机制

    - 插入数据 `INSERT INTO test (a) VALUES ('测试flashbackdrop')`; - 提交 `COMMIT`; - 错误地删除表 `DROP TABLE test`; - 使用 Flashback Drop 恢复表 `FLASHBACK TABLE test TO BEFORE DROP`; ##### 5. ...

    Oracle闪回技术详解

    闪回删除(Flashback Drop)可以轻松将一个已经被Drop的表还原回来。相应的索引、数据库约束也会被还原(除了外键约束)。例如,可以使用以下SQL语句来闪回删除表: SQL> flashback table emp to before drop ...

    Oracle闪回操作

    - **删除闪回(Flashback Drop)**: 对于被删除的表,可以使用`flashback table to before drop`来恢复,但需注意,恢复后的索引名可能还在回收站中,需要手动重命名: ```sql SQL> flashback table s_emp1 to ...

    dba数据恢复flashback

    - **闪回删除 (Flashback Drop):** 用于恢复被误删除的表。 - **闪回查询 (Flashback Query):** 查看数据库在任意历史时间点的状态。 - **闪回版本查询 (Flashback Version Query):** 显示行的版本随时间变化的历史...

    oracle_闪回15分钟前的数据操作写法

    Oracle闪回技术主要包括以下几种类型:闪回查询(Flashback Query)、闪回表(Flashback Table)、闪回事务查询(Flashback Transaction Query)、闪回数据库(Flashback Database)和闪回删除(Flashback Drop)。...

    利用oracle 闪回技术恢复数据

    5. **闪回删除(Flashback Drop)**:当误删了表或者分区时,可以通过`FLASHBACK TABLE`命令将其恢复回来,前提是没有执行过`PURGE`操作。 6. **闪回数据归档(Flashback Data Archive)**:这是对历史数据进行长期...

    彻底删除和闪回oracle表

    值得注意的是,闪回操作依赖于数据库的闪回日志(Flashback Log)和事务日志,因此必须确保这些日志文件有足够的空间以支持闪回操作。此外,闪回功能可能会受制于数据库的闪回区大小和回收站策略,过度依赖闪回可能...

    oracle 闪回oracle 闪回oracle 闪回oracle 闪回

    3. **闪回删除(Flashback Drop)**:允许管理员恢复被DROP操作删除的对象,如表、索引等,到它们被删除前的状态。 4. **闪回版本查询(Flashback Versions Query)**:提供了一种查询方式,可以看到特定行在不同...

    oracle闪回数据库

    3. 闪回删除:对于误删除的表,通过`FLASHBACK DROP`可以恢复。 4. 数据比较:`FLASHBACK QUERY`可用于对比当前数据与过去某时刻的数据,以分析变化。 监控闪回数据库的关键在于确保有足够的空间来存储闪回日志,...

    oracle flashback闪回技术

    如果一个管理员不小心使用DROP TABLE命令删除了表,可以通过Flashback Table来恢复。命令格式为`FLASHBACK TABLE table_name TO BEFORE DROP;`。但需要注意的是,这仅在表被放入回收站且未被其他操作覆盖的情况下...

Global site tag (gtag.js) - Google Analytics