`

Oracle 10g 中误删除(drop)表的恢复处理

 
阅读更多
在9i中Oracle引入了flashback的概念,可以将数据返回到某个时间点,
但对于诸如drop/truncate等DDL语句却尚不支持。进入Oracle10g,这一
缺陷得到了弥补。可以将丢失掉的表,通过flashback命令直接找回。
非常简单且易用。
首先,可以查看当前schema中的表:
SQL> select * from tab;

TNAME                    TABTYPE  CLUSTERID
------------------------ ------- ----------
RECYCLETEST              TABLE

然后删除该表:
SQL> drop table recycletest;

Table dropped.
检查表状态:
SQL> select * from tab;

TNAME                          TABTYPE  CLUSTERID
------------------------------ ------- ----------
BIN$04LhcpndanfgMAAAAAANPw==$0 TABLE

由此可知,Oracle将drop掉的表重命名了。而且对应的触发器,索引
等对象,所涉及到的表名,都已经对应修改。

假设现在有N个表都被drop掉了,那么如何查看被drop掉的表和在回收
站里面被重新命名后的名称呢?如下:
SQL> show recyclebin

ORIGINAL NAME    RECYCLEBIN NAME                OBJECT TYPE  DROP TIME
---------------- ------------------------------ ------------ ------------------
RECYCLETEST      BIN$04LhcpndanfgMAAAAAANPw==$0 TABLE        2004-02-16:21:13:31
或者:
select * from dba_recyclebin;
select * from user_recyclebin;

该命令需要在10g以上的版本的sqlplus中执行方可查看。
然后恢复该表:
SQL> FLASHBACK TABLE RECYCLETEST TO BEFORE DROP;

FLASHBACK COMPLETE.

可以看到删除的表已经被恢复了:
SQL> SELECT * FROM TAB;

TNAME                          TABTYPE  CLUSTERID
------------------------------ ------- ----------
RECYCLETEST                    TABLE

记住,将删除的表放在回收站中不会释放原有的表空间,要释放这些空
间,需要执行:
purge recyclebin;

那么如果10g中要彻底删除一个表,而不要将该表回收放入回收站中呢:
drop table recycletest purge;

由于drop一个表在Oracle中只是对该表重命名,而并没有迁移该表对应
的表空间,因此删除后的表如果没有purge,则会一直占用该表空间。
直到表空间不足时,Oracle首先会去回收站中按照先进先出的原则来清
理回收站中的表。
当然,也可以用手动的方式来清理指定的表:
purge table recycletest;
或者使用该对象在回收站中的名字:
purge table "BIN$04LhcpndanfgMAAAAAANPw==$0";
该命令将清除掉所有跟该表相关的对象,包括索引、约束、触发器等。如果想永
久的删除一个索引,则可以:
purge index in_test_01;
这个命令仅仅删除该表的索引,而不影响该表(回收站中的)。

有一种情况,drop表emp后,又创建了emp表,然后再次drop后再创建emp表,再drop:
create table emp(id number(10));
drop table emp;
create table emp(id number(10), name varchar2(100));
drop table emp;
create table emp(id number(10), name varchar2(100), sex varchar2(2));
drop table emp;
当执行purge table emp后,是purge掉哪个表呢?还是全部purge掉?
答案是跟前面自动清理的原理一样,每次清除第一个被drop掉的emp表,判断的依据是user_recyclebin.dropscn,根据该值的大小决定purge的顺序。

另外,如果要对drop掉的表做恢复处理,而此时又已经创建了表emp,那么如何恢复该表呢(由于已经存在该表名,不能直接恢复)。方法:
flashback table emp to before drop rename to emp_old;
即将恢复的表命名为其他名称的一个表。
恢复的时候跟purge的顺序是相反的,即最后一个被drop掉的最先被恢复。

更多内容可以参考该文档:
http://download.oracle.com/docs/cd/B19306_01/backup.102/b14192/flashptr004.htm#sthref634
http://www.oracle.com/technology/pub/articles/10gdba/week5_10gdba.html


分享到:
评论

相关推荐

    利用 Oracle 系统触发器防止误删除表操作

    利用oracle 系统触发器防止用户使用drop table 或truncate table 命令。

    oracle中误删除表后恢复语句(FLASHBACK)

    您可能感兴趣的文章:Oracle误删除表数据后的数据恢复详解Oracle7.X 回滚表空间数据文件误删除处理方法Oracle7.X 回滚表空间数据文件误删除处理方法Oracle7.X 回滚表空间数据文件误删除处理方法误删除$ORACLE_HOME/...

    Oracle 10G中的回收站

    回收站,从原理上来说就是一个数据...相信随着10G的大范围应用,这种情形应该比较少见了,我们可以充分利用10g的闪回功能来避免大量的人工误操作。DBA管理上的相关信息可以从USER_recyclebin(DBA_recyclebin)中获取。

    关于oracle10供了类似操作系统中的回收站功能

    在Oracle10g中,引入了一个回收站(Recycle Bin)的概念。回收站,从原理上来说就是一个数据字典表,放置用户Drop掉的数据库对象信息。被用户Drop的对象并没有被Oracle删除,仍然会占用空间。除非是用户手工进行Purge...

    赤兔Oracle数据库恢复软件 v11.6.zip

    31.支持对误删除数据的恢复,即使被删除数据的表中有LOB列,即使被删除数据的表中对应row directory中所有记录的offset都已经完全被Oracle清除 赤兔Oracle数据库恢复软件软件安装   把下载好的安装包解压到...

    PRM-DUL Oracle(数据库恢复工具) v4.1.zip

    1. 对使用DELETE命令误删除的数据的救援恢复支持 2. 对在字典模式下LOB数据Data Bridge功能增强,大幅度改善导出性能 3. 增加在非字典模式下LOB数据的Data Bridge支持。 4. 增加对字典模式/非字典模式数据加载...

    oracle学习文档 笔记 全面 深刻 详细 通俗易懂 doc word格式 清晰 连接字符串

     删除环境变量中的PATHT CLASSPATH中包含Oracle的值。  删除“开始”/“程序”中所有Oracle的组和图标。  删除所有与Oracle相关的目录,包括: C:\Program file\Oracle目录。 ORACLE_BASE目录。 C:\Documents ...

    Oracle对于误删误操作的数据进行恢复(flashback query、flashback drop、flashback table、flashback database)

    Oracle对于误删误操作的数据进行恢复。 日常工作中难免遇到自己或者别人误操作、删除、修改了数据库的数据。此时我们该如何恢复数据呢。   1、我们可以应用Flashback Query查询过去的数据 Flashback Query这一特性...

    SQL数据库修复软件

    SQL数据库置疑 SQL数据库损坏 SQL数据库修复软件 SQL数据库0字节 SQL系统表损坏 SQL误删除恢复 SQL 误删除表恢复 我们的修复率在100%,如果您已经尝试多家公司,请不妨再交给我们做,我们已经多次救援过被判‘死刑...

    Oracle闪回详解--实验

    闪回各种误删除操作:truncate、drop、delete。

    FLAHBACK详解

    FLAHBACK举例和使用说明,比较详细,重点介绍了3中方法恢复数据库:1.Flashback database ;...本人也误操作drop了oracle中的一张表,找了半天找到这个方法文档恢复成功了表和数据。很好用,希望大家支持下。

    数据库系统维保服务与评估.docx

    系统表空间(SYSTEM)表空间损坏 对于Oracle数据库来说,系统表空间是数据库的核心所在,如果SYSTEM表空间损坏,则数据库可能会无法启动。 在面对这种情况时,如果存在有效的备份,可以通过备份进行数据恢复,如果不...

Global site tag (gtag.js) - Google Analytics