Oracle删除表从回收站恢复

想起来很郁闷的一件事,昨天快下班的时候,登了两个用户,由于用户切换错了,Drop掉了所有的表。最后使用很多方式,都没能够如愿还原数据库信息。今天一上班使用最基本的方式,成功的还原了回收站的数据库表及其相关信息。

解决方案:

        查询当前用户删除的在回收站的数据表:

        select * from user_recyclebin where type='TABLE' order by droptime desc;

        根据查询的信息还原表(恢复表时,索引和表数据等相关信息都会自动恢复)

   flashback table '需要恢复的表名(original_name)' to before drop;

相关知识点梳理:

    

1. 表恢复

   对误删的表,只要没有使用 purge 永久删除选项,那么基本上是能从 flashback table 区恢复回来的。

   数据表和其中的数据都是可以恢复回来的,一般步骤有:

   a.从 flashback table 里查询被删除的数据表

select * from recyclebin order by droptime desc

   b.执行表的恢复

flashback table '需要恢复的表名' to before drop

2. 表数据恢复

   对误删的表记录,只要没有 truncate 语句,就可以根据事务的提交时间进行选择恢复。

   这功能也是  oracle 10g 以上提供的,一般步骤有:

   a. 先从 flashback_transaction_query 视图里查询,视图提供了供查询用的表名称、事务提交时间、undo_sql等字段。

select * from flashback_transaction_query where table_name='需要恢复数据的表名(大写)';

   b.查询删除的时间点

select to_char(sysdate, 'yyyy-mm-dd hh24:mi:ss') time,
       to_char(dbms_flashback.get_system_change_number) scn
  from dual;

   或者你知道大概记得删除点,你也可以这样试试查询,找出删除前的时间点

select * from '需要恢复数据的表名' as of timestamp to_timestamp('时间点', 'yyyy-mm-dd hh24:mi:ss');

   c.进行数据恢复

   通过第二步找到数据丢失的时间点,恢复极为简单,语句为

flashback table '需要恢复数据的表名' to timestamp to_timestamp('数据丢失的前一时间点','yyyy-mm-dd hh24:mi:ss');

   注意:在执行上述操作的时候,需要允许 oracle 修改分配给行的 rowid,这时候 oracle 需要给恢复的数据分配新的物理地址。

alter table table_name enable row movement;

  

猜你喜欢

转载自blog.csdn.net/hjinping/article/details/80201686