论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 scn 7433000;-->在这个点上查到数据(17110条)。


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


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


就问6不6?


6


 6


  6



上一篇:raid5因两块硬盘掉线导致的数据丢失恢复过程分享


下一篇:《ArcGIS Engine+C#实例开发教程》第四讲 状态栏信息的添加与实现