delete误删数据使用SCN号恢复(推荐)
问题描述:使用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号恢复,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
相关文章
SqlServer编写数据库表的操作方式(建库、建表、修改语句)
这篇文章主要介绍了SqlServer编写数据库表的操作方式(建库、建表、修改语句)的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下2016-09-09
mssql server 存储过程里,bulk insert table from ''路径+文件'',路径固定,文件名
mssql server 存储过程里,bulk insert table from ''路径+文件'',路径固定,文件名不固定的实现方法...2007-07-07
使用sqlserver官方驱动包调用存储过程遇到的坑及解决方法
这篇文章主要介绍了用sqlserver官方驱动包调用存储过程遇到的一个坑,解决方法大概就是换驱动包,在在存储过程首行添加 set nocount on ,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下2022-10-10
SqlServer2012中First_Value函数简单分析
SQL SERVER 2012 T-SQL新增几个聚合函数: FIRST_VALUE LAST_VALUE LEAD LAG,今天我们首先来简单分析下FIRST_VALUE,希望对大家有所帮助,能够尽快熟悉这个聚合函数2014-08-08


最新评论