delete误删数据使用SCN恢复

参考51CTO博客测试

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

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

SQL> select dbms_flashback.get_system_change_number from dual;文档

SQL> select current_scn from v$database;get

 

 2.建立测试数据,博客

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

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

 

 SQL> commit;table

3.这时候至关于数据建立完了,这以后的scn号码要知道,由于上边那两个scn号没有记录这个表的信息对我没用,若是如今查询current_scn号就有用了,这里测试我也不麻烦了,文档是参考的select

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;

 

 

 

 如今就恢复完成。

相关文章
相关标签/搜索