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

Oracle
Oracle数据库系统紧急故障处理方法
Oracle SQL性能优化系列学习一
Oracle 数据库操作技巧集
Oracle组件实现动态Web数据库
ORACLE常见错误代码的分析与解决二
ORACLE常见错误代码的分析与解决三
在Oracle 8x实现自动断开后再连接
深刻理解Oracle数据库的启动和关闭
Oracle对两个数据表交集的查询
Oracle 8i字符集乱码问题析及其解决办法
Oracle 数据库管理脚本命名规范
Oracle不同数据库间对比分析脚本
Oracle数据库安全策略
Oracle数据库的空间管理技巧
Oracle数据库系统使用经验六则
ORACLE数据库应用开发常见问题及排除
Oracle系统表外键的更名
Oracle约束管理脚本
如何确定Oracle数据库表重复的记录
Oracle数据库索引的维护

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-30   浏览: 63 ::
收藏到网摘: 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