SQL Server delete误删数据使用SCN号恢复的解决办法

2022-11-12 09:38:48
内容摘要
这篇文章主要为大家详细介绍了SQL Server delete误删数据使用SCN号恢复的简单示例,具有一定的参考价值,可以用来参考一下。 对此感兴趣的朋友,看看idc笔记做的技术笔记! 问题描
文章正文

这篇文章主要为大家详细介绍了SQL Server delete误删数据使用SCN号恢复的简单示例,具有一定的参考价值,可以用来参考一下。

对此感兴趣的朋友,看看idc笔记做的技术笔记!

问题描述:使用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;

【图片暂缺】

【图片暂缺】

现在就恢复完成。

总结

以上所述是小编给大家介绍的delete误删数据使用SCN号恢复,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对512笔记网站的支持!如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

注:关于SQL Server delete误删数据使用SCN号恢复的简单示例的内容就先介绍到这里,更多相关文章的可以留意

代码注释

作者:喵哥笔记

IDC笔记

学的不仅是技术,更是梦想!