ora_rowscn伪列的用途

简介:
ora_rowscn
对于每一行数据,ora_rowscn返回每一行最近被修改的大概时间.这对于判断一行数据
大概是在什么时间被修改的还是有用的.因oracle是通过事务提交对行所在数据块来
进行scn的跟踪的所以说它不精确.可以通过在创建表时使用行级别的依赖跟踪来获得
一个更加精确的scn.create table ... norowdependencies|rowdependencies

在对视图进行查询时不能使用ora_rowscn.但对于视图的基表是可以使用ora_rowscn.
也能在update或delete语句中的where子句中使用ora_rowscn

ora_rowscn不能用于回闪查询,但是可以用回闪版本查询来代替ora_rowscn.

ora_rowscn也不能用于外部表


获取行被修改的大根的scn
SQL> select ora_rowscn,t.test_id from test_jy t;

ORA_ROWSCN               TEST_ID
---------- ---------------------
    625591                     3


通过scn来获取修改行记录大概的时间
SQL> select scn_to_timestamp(ora_rowscn),t.test_id from test_jy t;

SCN_TO_TIMESTAMP(ORA_ROWSCN)                                                                   TEST_ID
-------------------------------------------------------------------------------- ---------------------
20-12月-12 06.23.22.000000000 下午                                                                   3

也可以通过时间来获得scn

SQL> select timestamp_to_scn(scn_to_timestamp(ora_rowscn)),t.test_id from test_jy t;

TIMESTAMP_TO_SCN(SCN_TO_TIMEST               TEST_ID
------------------------------ ---------------------
                        625590                     3
目录
相关文章
|
9月前
|
Oracle 关系型数据库
Oracle 根据某个字段获取第一条数据
Oracle 根据某个字段获取第一条数据
|
Oracle 关系型数据库
oracle学习78-oracle之单行函数之分组函数之课后练习
oracle学习78-oracle之单行函数之分组函数之课后练习
79 0
|
Oracle 关系型数据库
oracle学习80-oracle之单行函数之多表查询值之课后练习
oracle学习80-oracle之单行函数之多表查询值之课后练习
75 0
|
Oracle 关系型数据库
oracle学习72-oracle之单行函数之子查询课后练习2
oracle学习72-oracle之单行函数之子查询课后练习2
82 0
|
Oracle 关系型数据库
oracle学习87-oracle之基本的过滤和排序数据之课后练习
oracle学习87-oracle之基本的过滤和排序数据之课后练习
61 0
|
Oracle 关系型数据库
oracle学习75-oracle之单行函数之子查询课后练习2
oracle学习75-oracle之单行函数之子查询课后练习2
110 0
|
Oracle 关系型数据库
oracle学习76-oracle之单行函数之子查询之课后练习
oracle学习76-oracle之单行函数之子查询之课后练习
71 0
|
Oracle 关系型数据库
oracle学习74-oracle之单行函数之子查询之课后练习
oracle学习74-oracle之单行函数之子查询之课后练习
56 0
|
Oracle 关系型数据库
oracle学习73-oracle之单行函数之子查询课后练习2
oracle学习73-oracle之单行函数之子查询课后练习2
68 0