zoukankan      html  css  js  c++  java
  • Oracle 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可以用于数据的恢复等操作。

                                   

  • 相关阅读:
    超链接导航栏案例
    css中定位功能的特性
    background的使用
    数据库单表查询
    各种算法
    面向对象能做什么和特性及嵌套
    c3算法详解
    面向对象继承
    生成器
    迭代器
  • 原文地址:https://www.cnblogs.com/liyasong/p/oracle_scn.html
Copyright © 2011-2022 走看看