delete误删数据使用SCN恢复「建议收藏」

delete误删数据使用SCN恢复「建议收藏」参考51CTO博客 问题描述:使用scn号恢复误删数据 1.查询系统闪回的scn值以及当前日志的scn值,因为我这个是测试,创建的表是在在后边,所以scn值要大于下边这两个scn值,所以对我恢复数据没

参考51CTO博客

问题描述:使用scn号恢复误删数据

1.查询系统闪回的scn值以及当前日志的scn值,因为我这个是测试,创建的表是在在后边,所以scn值要大于下边这两个scn值,所以对我恢复数据没有用,如果我创建的数据是在下边这两个SCN值之前,也就是比这两个时间点SCN值小,就可以用这两个scn用来恢复数据,但是我下边这个实验创建的测试表晚,就不行了

SQL> select dbms_flashback.get_system_change_number from dual;

delete误删数据使用SCN恢复「建议收藏」

SQL> select current_scn from v$database;

delete误删数据使用SCN恢复「建议收藏」

 

 2.创建测试数据,

SQL> create table aa(id int,name varchar2(10),adress varchar2(10));

delete误删数据使用SCN恢复「建议收藏」

SQL> insert into aa
2 values(111,”steven”,”beijing”);

delete误删数据使用SCN恢复「建议收藏」

 

 SQL> commit;

3.这时候相当于数据创建完了,这之后的scn号码要知道,因为上边那两个scn号没有记录这个表的信息对我没用,如果现在查询current_scn号就有用了,这里测试我也不麻烦了,文档是参考的

SQL> select dbms_flashback.get_system_change_number from dual;

delete误删数据使用SCN恢复「建议收藏」

 

 这个scn值是可以用来恢复数据的

4.删除数据模拟情景,然后查询不到数据。

SQL> delete from aa;

1 row deleted.

SQL>
SQL>
SQL> commit;

Commit complete.

delete误删数据使用SCN恢复「建议收藏」

 

 5.恢复数据

SQL> select * from aa as of scn 1116916;

delete误删数据使用SCN恢复「建议收藏」

 

 可以查询到这个scn值以前的数据,可以用来恢复

SQL> insert into sys.aa select * from sys.aa as of scn 1116916;

delete误删数据使用SCN恢复「建议收藏」

 

 delete误删数据使用SCN恢复「建议收藏」

 

 现在就恢复完成。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/10589.html

(0)
上一篇 2022-12-25
下一篇 2022-12-25

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注