您在这里:首页 > 学员专区 > 技术文章
Oracle视频
Oracle
CUUG课程

Oracle 9i中闪回查询操作实例

 

在利用闪回功能前需要确认:

1、用户有对dbms_flashback包有执行权限!

 

2、进行闪回查询必须设置自动回滚段管理,在init.ora设置参数UNDO_MANAGEMENT=AUTO,参数UNDO_RETENTION=n,决定了能往前闪回的最大时间,值越大就需要越多Undo空间。


Oracle 9i中闪回查询操作实例
查看Oracle中Delete和Commit操作的流程分析

例:Oracle 9i的Flashback Query操作。

 

(1)创建闪回查询用户

SQL> create user test identified by test;

SQL> grant connect, resource to test;

SQL> grant execute on dbms_flashback to test;

SQL> connect test/test;

 

(2)创建测试表,插入测试记录

SQL> create table test(id number(3));

SQL> insert into test values(1);

SQL> insert into test values(2);

SQL> commit;

注意:在执行步骤3或者步骤4之前,等待5分钟。

 

(3)删除记录

SQL> delete from test where id=1;

SQL> commit;

通过以上的操作,我们插入了两条记录,并删除了其中一条记录。在以下的操作中,我们将通过flashback query找到删除的记录

 

(4)闪回查询(分别通过timestamp和scn查询)

SQL> select * from test as of timestamp sysdate - 5/1440;

ID

----

1

2

SQL> select * from test as of scn 8173800;

ID

----

1

2

 

可以看出,虽然删除记录并提交,但是通过闪回操作,仍能查询到删除前的两条记录。需要注意Oracle每5分钟记录一次SCN到SMON_SCN_TIME,并将SCN和对应时间的映射进行纪录。如果原来插入的记录到做闪回操作的时间在5分钟之内,用基于时间的闪回查询可能得不到记录,因为基于时间点的查询实际上是转化为最近的一次SCN,然后从这个SCN开始进行恢复。因此,如果需要精确的查询可以采用基于SCN的闪回查询,可精确闪回到需要恢复的时间。可以通过DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER语句获取SCN。

(文章来自网络,如有侵权请来信告知,本站将在第一时间删除。)

相关文章 [上一篇] Oracle闪回恢复区(二)
010-88589926(88587026)
CUUG热门培训课程
Oracle DBA就业培训
CUUG名师
网络课程
技术沙龙
最新动态

总机:(010)-88589926,88589826,88587026 QQ讨论群:243729577 182441349 邮箱:cuug_bj@cuug.com
通信地址:北京市海淀区紫竹院路98号北京化工大学科技园609室(CUUG)邮政编码:100089 
中国UNIX用户协会 Copyright 2010  ALL Rights Reserved 北京神脑资讯技术有限公司
京ICP备11008061号  京公网安备110108006275号