Oracle 10g中找回误删数据

1. 进行查询闪回

Select * From 表名 As Of Timestamp to_Timestamp('2009-7-24  18:07:30','yyyy-mm-dd hh24:mi:ss')

2. 闪回的数据重新插入到机表中

Insert Into 表名 
(
Select * From 表名 As Of Timestamp to_timestamp('2009-07-24 16:08:30','YYYY-MM-DD HH24:MI:SS')

3. 恢复被删除的基表

Flashback Table 表名 To Before Drop;

4.数据库闪回

Flashback Database To Scn sid; --sid:指定的系统改变号
Flashback Database To Timestamp to_timestamp('2009-07-24 16:08:30','YYYY-MM-DD HH24:MI:SS')

5、获得当前SCN
  如果能够确切知道删除之前SCN最好,如果不知道,可以进行闪回查询尝试.
  SQL>select dbms_flashback.get_system_change_number from dual;

6、根据时间获得scn号

  select timestamp_to_scn(to_timestamp('2013-05-29 09:00:00','YYYY-MM-DD HH:MI:SS')) from dual;
  结果:13526973
  然后可以根据这个数据进行还原操作
  create table reporttest as select * from reportinfo where 1=0;
  insert into reporttest select * from reportinfo AS OF SCN 13526973;

  --上面两句应该可以合成一句
  create table reporttest as select * from reportinfo AS OF SCN 13526973;

7、可以查看当前schema中的表

 select * from tab;

假设现在有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;

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

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

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

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





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值