当前所在位置:珠峰网资料 >> 计算机 >> Oracle认证 >> 正文
oracle flashback闪回(一)
发布时间:2010/10/24 10:01:36 来源:www.xue.net 编辑:城市总裁吧

    1、必须设定undo保留时间足够大以能够重构需要闪回的数据

    ALTER SYSTEM SET UNDO_RETENTION=; seconds值是undo数据保持的秒数。

    Flashback view是由undo retention interval来限制的。

    2、包DBMS_FLASHBACK提供了需求接口

    call dbms_flashback.enable_at_time(‘2010-10-19:11:00:00’);

    call dbms_flashback.disable();

    -------------------------------------

    enable_at_time:会话级的enable flashback,映像时间被设定为最接近指定时间戳的scn

    enable_at_system_change_number:将数据库闪回到指定的scn号。

    get_system_change_number:返回当前的scn。

    disable:这个存储过程允许我们在整个会话内停止flashback并将你带回当前时间的数据状态。

    ----------

    dbms_flashback.enable存储过程不可以在有活动事务的时候执行,并且,这个包不能用sys身份执行。

    在使用DBMS_FLASHBACK.ENABLE_AT_TIME前,你必须设定你的NLS_DATE_FORMAT的精确程度,Oracle默认的是精确到天

    3、timestamp 与scn(系统改变号) 的对应关系

    事实上,Oracle在内部都是使用scn,即使你指定的是as of timestamp,oracle也会将其转换成scn,系统时间标记与scn之间存在一张表,即SYS下的SMON_SCN_TIME表。

    每隔5分钟,系统产生一次系统时间标记与scn的匹配并存入sys.smon_scn_time表,该表中记录了最近1440个系统时间标记与scn的匹配记录,由于该表只维护了最近的1440条记录,因此如果使用as of timestamp的方式则只能flashback最近5天内的数据(假设系统是在持续不断运行并无中断或关机重启之类操作的话)。SYS.SMON_SCN_TIME最多拥有1440条记录。这个最大记录数是这样计算出来的,ORACLE平均每5分钟同步一次该表数据,最大保存最近5天的记录,因此就相当于12(每小时更新次数)*24*5=1440。

    可以用sql验证一下:

    Sql代码

    select scn,to_char(time_dp,'yyyy-mm-dd hh24:mi:ss') from sys.smon_scn_time;

    10g中提供了两个函数scn_to_timestamp() 和timestamp_to_scn() 用来执行时间戳和SCN的转换。

    下面使用闪回进行演示一下:

    1、登陆到数据库。

    Sql代码

    C:\>sqlplus tivan/tivan

    SQL*Plus: Release 10.2.0.1.0 - Production on 星期二 10月 19 22:24:03 2010

    Copyright (c) 1982, 2005, Oracle.  All rights reserved.

    连接到:

    Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production

    With the Partitioning, OLAP and Data Mining options

    2、查看表的记录。

    Sql代码

    SQL> select count(*) from t1

    2  ;

    COUNT(*)

    ----------

    8302

广告合作:400-664-0084 全国热线:400-664-0084
Copyright 2010 - 2017 www.my8848.com 珠峰网 粤ICP备15066211号
珠峰网 版权所有 All Rights Reserved