探讨ORACLE的SCN机制(1)
来源:互联网 发布:利达消防主机编程 编辑:程序博客网 时间:2024/05/22 06:35
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 recoveryORA-01110: data file 8: 'D:\APP\ASUS\ORADATA\WAREHOUSE\TEST03.DBF'SQL> select checkpoint_change# from v$database;CHECKPOINT_CHANGE#------------------ 1148279SQL> select file#,checkpoint_change# from v$datafile_header where file#=8; FILE# CHECKPOINT_CHANGE#---------- ------------------ 8 1147868SQL> select file#,checkpoint_change#,last_change# from v$datafile where file#=8; FILE# CHECKPOINT_CHANGE# LAST_CHANGE#---------- ------------------ ------------ 8 1147868 1148597SQL> 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
- 探讨ORACLE的SCN机制(1)
- 探讨ORACLE的SCN机制(2):文件检查点
- Oracle的SCN机制
- 探究ORACLE的SCN机制(3):Begin Backup
- Oracle SCN机制解析
- Oracle SCN机制解析
- Oracle SCN机制解析
- Oracle SCN 机制
- Oracle SCN机制解析
- Oracle SCN时间机制
- Oracle SCN 实现机制总结
- Oracle scn 的理解
- oracle的SCN
- Oracle锁机制及锁的探讨
- Oracle锁机制及锁的探讨
- Oracle锁机制及锁的探讨
- Oracle锁机制及锁的探讨
- Oracle中SCN的理解
- EXC_BAD_ACCESS 问题
- 工作方法总结
- 高并发大型网站架构设计
- 2.3
- <1>移动设备的网络通信 http /socket
- 探讨ORACLE的SCN机制(1)
- 【数据结构】链式前向星
- 500 OOPS: cannot change directory:/home/lubinsu
- /dev/zero和/dev/null的区别
- c小技巧--sprintf可控格式化输出
- MFC 多线程总结
- 横向 tableView
- Transactional replication 的Snapshot 文件在什么情况下会被清除
- Bash shell之管道命令