Oracle中scn講解

       SCN
System Change Numbers (SCNs)&System Commit Numbers(系統改變號&系統提交號)
A system change number (SCN) is a logical, internal time stamp used by Oracle Database;
********************************************************************************************************


SCN特點:
SCN本身也是一種時間
SCN是從你建庫開始單調遞增的序列;當你將SCN號用完了,數據庫就不能運行; 但是幾百年之內是不會用完的!
SCN是一個重要機制,在數據恢復、Data Guard、Streams複製、RAC 節點間的同步等各個功能中起着重要作用;
*********************************************************************************************************
Oracle數據庫SCN的種類:

1.數據庫當前的SCN

SYS@orcl11g> select current_scn from v$database;

CURRENT_SCN
--------------------
    1159919

SYS@orcl11g> select dbms_flashback.get_system_change_number() from dual;

DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER()
----------------------------------------------------------------------
                                  1159919

SYS@orcl11g>select dbms_flashback.get_system_change_number() from dual
 2  union all
 3* select current_scn from v$database

DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER()
----------------------------------------------------------------------
                              1159919
                                1159919

2.數據庫的檢查點scn(系統scn) -- 來源控制文件,用來標識當前數據庫的數據更新的信息(用來表示數據庫的更新行爲)
SYS@orcl11g> select checkpoint_change#,current_scn from v$database;

CHECKPOINT_CHANGE#  CURRENT_SCN
-------------------------------- ----------------------
          1666278                  1676455

3.數據文件的檢查點scn --來源控制文件,標識每一個文件是什麼時候同步的
SYS@orcl11g> select file#,checkpoint_change# from v$datafile order by 1;

   FILE#  CHECKPOINT_CHANGE#
-----------  --------------------------------
        1            1666278
        2            1666278
        3            1666278
        4            1666278
        5            1666278
        6            1666278
        7            1384282
        8            1666278
        9            1666278

SYS@orcl11g> select tablespace_name,file_id from dba_data_files where file_id=7;

TABLESPACE_NAME      FILE_ID
------------------------------ ----------
TBS02                                7

SYS@orcl11g> select tablespace_name,status from dba_tablespaces  where tablespace_name='TBS02';

TABLESPACE_NAME       STATUS
------------------------------ ------------
TBS02                            OFFLINE


4.數據文件頭部的檢查點SCN -- 來源於數據文件頭部

SYS@orcl11g> select file#,checkpoint_change# from v$datafile_header;

   FILE#  CHECKPOINT_CHANGE#
  --------- ---------------------------------
        1            1676699
        2            1676699
        3            1676699
        4            1676699
        5            1676699
        6            1676699
        7            1676699
        8            0
        9            1676699

9 rows selected.
如果是0的話,說明數據文件已經離線,不再讀取這個數據文件

5.數據文件的last_change# --數據文件的關閉SCN(結束SCN)

SYS@orcl11g> select file#,checkpoint_change#,last_CHANGE# from v$datafile;

  FILE# CHECKPOINT_CHANGE# LAST_CHANGE#
---------- -------------------------------- ----------------------
        1            1737727                   (null)
        2            1737727                   (null)
        3            1737727                   (null)
        4            1737727                   (null)
        5            1737727                   (null)
        6            1737727                   (null)
        7            1737727                   (null)
        8            1737727                   (null)
        9            1737727                   (null)

那系統是如何產生一個最新的 SCN 的?
是由當時的 timestamp 轉換過來的。每當需要產生一個最新的 SCN 到 redo 記錄時,系統獲取當時的 timestamp,將其轉換爲數字作爲 SCN。

TIME & SCN的相互轉換函數:

SYS@orcl11g> select scn_to_timestamp(1906338) from dual;

SCN_TO_TIMESTAMP(1906338)
------------------------------------------------
26-JUN-13 10.52.09.000000000 AM


SYS@orcl11g> select timestamp_to_scn(to_timestamp('2013-06-26 10:53:27','yyyy-mm-dd hh24:mi:ss')) from dual;

TIMESTAMP_TO_SCN(TO_TIMESTAMP('2013-06-2610:53:27','YYYY-MM-DDHH24:MI:SS'))
-----------------------------------------------------------------------------------------------------------------
                                                           1906370

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章