您的位置:首页 > 数据库 > Oracle

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

2017-09-18 12:45 344 查看
啊!假如说我有一张表叫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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  恢复 数据 绝杀