Welcome 微信登录

首页 / 数据库 / MySQL / ORA_ROWSCN伪列的用途

ora_rowscn对于每一行数据,ora_rowscn返回每一行最近被修改的大概时间.这对于判断一行数据大概是在什么时间被修改的还是有用的.因Oracle是通过事务提交对行所在数据块来进行scn的跟踪的所以说它不精确.可以通过在创建表时使用行级别的依赖跟踪来获得一个更加精确的scn.create table ... norowdependencies|rowdependencies在对视图进行查询时不能使用ora_rowscn.但对于视图的基表是可以使用ora_rowscn.也能在update或delete语句中的where子句中使用ora_rowscnora_rowscn不能用于回闪查询,但是可以用回闪版本查询来代替ora_rowscn.ora_rowscn也不能用于外部表获取行被修改的大根的scnSQL> 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也可以通过时间来获得scnSQL> 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                   3ORA-01565: error in identifying file "+DATA/rac/dataile/datfile/system"Oracle启动实例时使用参数文件的顺序相关资讯      ORA_ROWSCN  Oracle伪列 
  • 根据ora_rowscn删除重复插入的数据  (01/06/2014 18:59:17)
本文评论 查看全部评论 (0)
表情: 姓名: 字数