当前位置: 首页 > 图文教程 > 数据库 > Oracle > 理解SCN与TimeStamp的相互转换

Oracle
Oracle常用dump命令,记录一下备查。
Oracle存储过程之数据库中获取数据实例
Oracle存储过程入门学习基本语法
java.sql.SQLException: 内部错误: Unable to construct a Datum from the specified input
Oracle 函数大全[字符串函数,数学函数,日期函数]
Oracle 自增(auto increment) 或 标识字段的建立方法
oracle 存储过程加密的方法
Oracle针对数据库某一行进行操作的时候,如何将这一行加行锁
Oracle 忘记密码的找回方法
Oracle 数据库导出(exp)导入(imp)说明
oracle 常见等待事件及处理方法
Oracle9i 动态SGA,PGA特性探索
PDO取Oracle lob大字段,当数据量太大无法取出的问题的解决办法
ORACLE 数据库RMAN备份恢复
用Mimer Validator检查SQL查询
oracle执行cmd的实现方法
ORACLE 正则解决初使化数据格式不一致
Oracle 触发器的使用小结
oracle 时间格式的调整
Oracle 10g的DBA无法登录解决方案

Oracle 中的 理解SCN与TimeStamp的相互转换


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-30   浏览: 77 ::
收藏到网摘: n/a

在Oracle10g中,为了增强闪回操作(flashback),现已提供了函数对于SCN和时间戳来进行相互转换。

首先我们需要通过dbms_flashback.get_system_change_number,它可以获取系统当前的SCN值:

SQL> col scn for 9999999999999
SQL> select dbms_flashback.get_system_change_number scn from dual;
SCN
--------------
8908390522972

我们通过scn_to_timestamp函数可以将SCN转换为时间戳:

SQL> select scn_to_timestamp(8908390522972) scn from dual;
SCN
---------------------------------
05-JAN-07 10.56.30.000000000 AM

然后通过timestamp_to_scn则可以将时间戳转换为SCN:

SQL> select timestamp_to_scn
(scn_to_timestamp(8908390522972)) scn from dual;
SCN
--------------
8908390522972

请注意,通过这两个函数,最终Oracle将SCN和时间的关系建立起来,在Oracle10g之前,我们是没有办法通过函数转换得到SCN和时间的对应关系的,但一般可以通过logmnr分析日志来获得。

美中不足的是,这种转换需要依赖于数据库内部的数据记录,对于久远的SCN则不能转换,具体的示例如下:

SQL> select min(FIRST_CHANGE#) scn,
max(FIRST_CHANGE#) scn from v$archived_log;
SCN SCN
------------------ ------------------
8907349093953 8908393582271
SQL> select scn_to_timestamp(8907349093953) scn from dual;
select scn_to_timestamp(8907349093953) scn from dual
*
ERROR at line 1:
ORA-08181: specified number is not a valid system change number
ORA-06512: at "SYS.SCN_TO_TIMESTAMP", line 1
ORA-06512: at line 1
SQL> select scn_to_timestamp(8908393582271) scn from dual;

SCN
-------------------------------------------
05-JAN-07 11.45.50.000000000 AM