ITPub博客

首页 > 数据库 > Oracle > 如何查询oracle表中的update操作记录的scn

如何查询oracle表中的update操作记录的scn

Oracle 作者:yaoronghui2005 时间:2020-08-05 13:55:50 0 删除 编辑

oracle查询表中bai数据行(row)上最后的duDML时间

  zhi第一种方式(块级跟踪):

  select ora_rowscn,

  dbms_rowid.ROWID_BLOCK_NUMBER(rowid) blockid,scn_to_timestamp(ora_rowscn)

  from hs_futures.fuentrust t

  order by scn_to_timestamp(ora_rowscn);

  dbms_rowid.ROWID_BLOCK_NUMBER(rowid):是为获取数据dao所在块的IDscn_to_timestamp(ora_rowscn):获取数据最所修改的时间数据发现变化后通过上面SQL语句可以查看到数据最后修改的时间,注意因为是同一个块上,所以这个块上只要有DML操作那么所有数据的scn都更新了,所以凡是跟这条记录在同一个块上数据获取到的ora_rowscn和scn_to_timestamp(ora_rowscn)两个值都发生了相应的变化。

  第二种方式(行级跟踪):

  create table hs_futures.fuentrust_test1 rowdependencies asselect * from hs_futures.fuentrust

  用以上语句创建一个基于ROWDEPENDENCIES模式的表,然后用第一种方法中的SQL去查询此表数据中的ora_rowscn,scn_to_timestamp(ora_rowscn)两个值,修改其中的某一条记录然后再去查询那个值发现发生变化的只是被修改那条记录的这两个值发生了变化,而在同一个块中没有被修改的其它记录这两个值是不会产生变化的。

-------20200805 我测试了一下,但是发现修改其中一条记录的时候这个ora_rowscn还是变化的呀

create table ttt rowdependencies as select 'thomas_'||rownum as seq_name from dual connect by rownum <= 10;

select * from ttt for update;

select ora_rowscn,

         dbms_rowid.ROWID_BLOCK_NUMBER(rowid) blockid,

       scn_to_timestamp(ora_rowscn)

         from ttt

         order by scn_to_timestamp(ora_rowscn);


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/450962/viewspace-2709390/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论
  • 博文量
    153
  • 访问量
    153734