oracle-SCN系统改变号

SCN

system change number

我们看到的SCN是一串数字,由时间经过函数算出的,其实就是时间。但时间的比较复杂,不如转换成数字比较。

给一个日志加scn号,其实就是给日志加上时间点。

2常见的SCN

对于scn的理解

控制文件中有两个scn,开始和结束,数据文件头部也有一个scn号。

当数据库正常运行时,控制文件的开始scn号和数据文件的scn号一直,结束scn号为空。当正常关闭数据库时,三个号统一一致。

当非正常关闭时,结束scn号未被写入,再启动数据库时,由于结束scn号为空,数据库知道异常关闭,则会进行实例异常恢复。

在日志文件中,每一条日志都有scn号,而且日志循序写的。同时每个日志块在头部也有开始scn号和nextscn号。

inactive是表示buffer pool脏块写进磁盘去,可以被覆盖。

active表示buffer pool脏块还没写进磁盘去,不可以被覆盖,实例恢复需要。

current表示当前所用的日志文件。

所以系统和文件的SCN是与最老的 active的日志的first的SCN一致的。

具体的实例恢复,还得定位到最老的*active的日志里面的LRBA的具体日志。

相关推荐
Rick19937 分钟前
Redis 分布式锁:核心使用场景
数据库·redis·分布式
身如柳絮随风扬1 小时前
Redis如何实现高效插入大量数据
数据库·redis·缓存
Dream of maid1 小时前
Mysql(3)运算符
数据库·mysql·adb
XDHCOM2 小时前
ORA-41722权限不足引发数据库变更通知故障,Oracle报错修复与远程处理方案引热议
数据库·oracle
修己xj2 小时前
人大金仓 KingbaseES V8 数据库 Docker 部署指南
数据库
Yushan Bai2 小时前
windows环境oracle 11.2.0.1版本数据库启动报错ORA-01589问题的处理
数据库·oracle
予早2 小时前
Redis 设置库的数量
数据库·redis·缓存
奔跑吧树袋熊2 小时前
Oracle 9i 与 19c 跨版本字符集乱码(US7ASCII ↔ AL32UTF8)DBLink 解决方案
数据库·oracle
byzh_rc2 小时前
[AI编程从入门到入土] 配置文件
java·数据库·ai编程
oradh2 小时前
Oracle数据库模式、对象的入门概述
数据库·oracle·oracle数据库基础