首页 > 数据库技术 > 详细

Oracle SCN

时间:2019-08-12 00:01:52      阅读:112      评论:0      收藏:0      [点我收藏+]

  SCN定义

  SCN (System Chage/Commit Number ) 记录系统改变的一个号码,用于标记数据库在某个时刻提交的版本。在一个事物发生提交操作(commit)时,会赋予事物一个唯一SCN值。每个数据库都有个全局的SCN 生成器。SCN是递增的,但是可能会不连贯。数据库的事物根据SCN排序确定先后,Oracle 也会根据SCN做数据库的一致性读(Read Consistency)操作。以及数据的恢复机制中也会用到SCN。

  技术分享图片

 

  SCN 由两部分组成,SCN Wrap 与 SCN Base 。其中高位SCN Wrap 2个字节 ,低位SCN Base 4个字节。原因是SCN变化很快,所以4个字节的SCN 数不够用,所以又加了个高位,为了兼容一些系统才设计成两部分。

  SCN 获取

   1.使用 dbms_flashback.get_system_change_number 获取(oracle 9i 及以后):

  select dbms_flashback.get_system_change_number from dual;                                                   

  2.从V$database 视图中获取(oracle 10 g 及以后):

  select current_scn from v$database; 

  SCN 应用

  SCN 一般在数据发生commit 或者回滚的时候改变。在控制文件、数据文件头、数据块、日志文件头、日志文件 change vector 中都有SCN,但其作用各不相同。

  (1) 数据文件

  数据文件头中包含了该数据文件的Checkpoint SCN ,表示该数据文件最后一次执行检查点操作时的 SCN。对于每个数据文件,都包含一个SCN的条目,包含SCN值及检查点发生的时间。在数据库启动时,通过对比控制文件的SCN信息和数据文件头中的SCN信息,来确保数据库的一致性和判断是否需要进行文件恢复。

  (2) 日志文件

  在日志文件中,包含两个SCN条目,Low SCN 和 Next SCN 。这两个SCN可以标志出该日志文件中所有介于两个SCN的重做信息。对于正在使用的日志文件(状态为current的日志文件),next SCN值为 ffffff 。日志中的SCN可以用于数据的恢复等操作。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

                               

 

Oracle SCN

原文:https://www.cnblogs.com/liyasong/p/oracle_scn.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!