共计 902 个字符,预计需要花费 3 分钟才能阅读完成。
问题描述:使用 scn 号恢复误删数据
1. 查询系统闪回的 scn 值以及当前日志的 scn 值,因为我这个是测试,创建的表是在在后边,所以 scn 值要大于下边这两个 scn 值,所以对我恢复数据没有用,如果我创建的数据是在下边这两个 SCN 值之前,也就是比这两个时间点 SCN 值小,就可以用这两个 scn 用来恢复数据,但是我下边这个实验创建的测试表晚,就不行了
SQL select dbms_flashback.get_system_change_number from dual;
SQL select current_scn from v$database;
2. 创建测试数据,
SQL create table aa(id int,name varchar2(10),adress varchar2(10));
SQL insert into aa 2 values(111,'steven','beijing');
SQL commit;
3. 这时候相当于数据创建完了,这之后的 scn 号码要知道,因为上边那两个 scn 号没有记录这个表的信息对我没用,如果现在查询 current_scn 号就有用了,这里测试我也不麻烦了,文档是参考的
SQL select dbms_flashback.get_system_change_number from dual;
这个 scn 值是可以用来恢复数据的
4. 删除数据模拟情景,然后查询不到数据。
SQL delete from aa;
1 row deleted.
SQL SQL SQL commit;
Commit complete.
5. 恢复数据
SQL select * from aa as of scn 1116916;
可以查询到这个 scn 值以前的数据,可以用来恢复
SQL insert into sys.aa select * from sys.aa as of scn 1116916;
现在就恢复完成。
总结
以上所述是丸趣 TV 小编给大家介绍的 delete 误删数据使用 SCN 号恢复,希望对大家有所帮助,如果大家有任何疑问请给我留言,丸趣 TV 小编会及时回复大家的。在此也非常感谢大家对丸趣 TV 网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
向 AI 问一下细节
丸趣 TV 网 – 提供最优质的资源集合!
正文完