论ORACLE中如何恢复被delete的表中数据

前端之家收集整理的这篇文章主要介绍了论ORACLE中如何恢复被delete的表中数据前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

啊!假如说我有一张表叫t1,今天一不小心把执行了如下命令:

delete from t1全部删除了。

也许到这里你还并不害怕,不行就flashback就是了。抱歉,我今天又做了一个purge recyclebin

擦,完蛋了。彻底无法恢复了吗?

当然不是,要知道recyclebin是存在内存中的,真正的数据肯定是保存在文件里的,那么从哪里恢复啊,当然是重做日志文件,找到重做日志文件里的SCN号,然后缩小SCN号范围,找到待恢复数据。

第一步:select dbms_flashback.get_system_change_number from dual;-->查找当前的SCN号(这里是7455407),如果你知道删除数据前的SCN号就更简单了


第二步:select count(*) from t1 as of scn 7455407;-->查询当前SCN下的数据(当前查到的是0,因为数据已经删除了)


第三步:缩小SCN范围,即往前推。

select count(*) from t1 as of scn7433000;-->在这个点上查到数据(17110条)。


第四步:insert into t1 select * from t1 as of scn 7443000;-->恢复数据


哈哈,是不是很简单啊!这才是终极必杀技哦!


就问6不6?


6


6


6

猜你在找的Oracle相关文章