探讨ORACLE的SCN机制(1)

本文深入探讨了Oracle数据库的SCN(System Change Number)机制,包括在数据库打开过程中SCN的比较与检查,以及如何判断是否需要进行实例恢复和介质恢复。通过验证步骤,解释了当数据文件的SCN小于数据库的checkpoint_change#时,系统提示需要进行物理修复的情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

oracle 数据库的打开过程进行的检查操作

       第一步:Oracle将数据文件头中的启动SCN与数据文件检查点SCN比较,即比较v$datafile_header.checkpoint_change#与对应文件v$datafile.checkpoint_change#,同时数据库文件头的checkpoint_change#等于v$database 的checkpoint_change#.
       第二步:第一步成功的情况下,Oracle接下来再比较数据文件头中的SCN和控制文件中数据文件的终止SCN.即比较v$datafile_header.checkpoint_change#与对应文件的v$datafile.last_chage#;如果这个值也匹配,就意味着所有数据块已经提交,因此数据 库不需要进行恢复,此时数据库直接打开。当所有的数据文件都打开之后,在线且可读写的数据文件终止SCN再次被设置为NULL,即把v$datafile.last_chage#设置为NULL,表示数据文件已经打开并能 够正常使用了。有些表空间是只读的,这时控制文件中的系统检查点SCN号会不断增长,而数据文件SCN号和文件头中的启动SCN(会停止更新直到表空间又 设置为可读写),显然这时系统检查点SCN号会大于数据文件SCN和文件头启动SCN。

       下面对上面的结论进行验证:






       上面的第二步提到的是怎么判断是否需要进行实例恢复的原理。那么,对于介质恢复又是怎样呢?

       其实,在第一步的时候,如果对应数据文件的文件头检查点,也就是v$datafile_header.checkpoint_change#,小于v$database.checkpoint_change#的话,这就说明该数据文件是以前版本的数据文件,需要进行物理修复。

       如下,让一个数据文件离线,然后把该文件上线的时候,就会报需要进行介质恢复,而此时的SCN刚好证明了上面的观点。

SQL> alter database datafile  'D:\APP\ASUS\ORADATA\WAREHOUSE\TEST03.DBF' online;
alter database datafile  'D:\APP\ASUS\ORADATA\WAREHOUSE\TEST03.DBF' online
*
ERROR at line 1:
ORA-01113: file 8 needs media recovery
ORA-01110: data file 8: 'D:\APP\ASUS\ORADATA\WAREHOUSE\TEST03.DBF'


SQL> select checkpoint_change# from v$database;

CHECKPOINT_CHANGE#
------------------
           1148279

SQL> select file#,checkpoint_change# from v$datafile_header where file#=8;

     FILE# CHECKPOINT_CHANGE#
---------- ------------------
         8            1147868

SQL>  select file#,checkpoint_change#,last_change# from v$datafile where file#=8;

     FILE# CHECKPOINT_CHANGE# LAST_CHANGE#
---------- ------------------ ------------
         8            1147868      1148597

SQL> select a.file#,b.name ,a.status from v$datafile a,v$tablespace b  where a.ts#=b.ts#  and b.name='TEST01';

     FILE# NAME                           STATUS
---------- ------------------------------ -------
         6 TEST01                         ONLINE
         8 TEST01                         RECOVER


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值