数据库教程:delete误删数据使用SCN号恢复(推荐)

问题描述:使用scn号恢复误删数据 1.查询系统闪回的scn值以及当前日志的scn值,因为我这个是测试,创建的表是在在后边,所以scn值要大于下边这两个scn值,所以对我恢复数据没有

问题描述:使用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号恢复(推荐)

现在就恢复完成。

总结

以上所述是小编给大家介绍的delete误删数据使用scn号恢复,希望对大家有所帮助

需要了解更多数据库技术:delete误删数据使用SCN号恢复(推荐),都可以关注数据库技术分享栏目—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/dtteaching/628582.html

(0)
上一篇 2021年5月30日
下一篇 2021年5月30日

精彩推荐