加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Oracle SCN

发布时间:2020-12-12 12:40:32 所属栏目:百科 来源:网络整理
导读:SCN定义 SCN (System Chage/Commit Number )?记录系统改变的一个号码,用于标记数据库在某个时刻提交的版本。在一个事物发生提交操作(commit)时,会赋予事物一个唯一SCN值。每个数据库都有个全局的SCN?生成器。SCN是递增的,但是可能会不连贯。数据库的事

  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可以用于数据的恢复等操作。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读