oracle中scn(系统改变号)
系统scn: select checkpoint_change# from v$database;
文件scn: select name,checkpoint_change# from v$datafile;
结束scn: select name,last_change# from v$datafile;
数据文件头部scn: select name,checkpoint_change# from v$datafile_header;
系统scn、文件scn、结束scn,这三者是在控制文件中,数据文件头部scn在数据文件上。
数据库正常运行,系统scn、文件scn、数据文件头部scn(也称为开始scn),这三者是相同的,而结束scn是空,即无穷大(因为正常运行,还未关闭啊),这是正常运行的情况,那么当正常关闭时,四者的scn号是相同的。假如发生非正常关闭,结束scn是空值,那么下次启动数据库,oracle发现结束scn是空值,就知道上次是非正常关闭,所以就要进行实例恢复了。实例恢复需要的是redo log,那么oracle是如何确定使用哪个redo log?以及确定之后又该从该redo log哪里进行恢复的呢?下面做个实验。。。
当前数据库的系统scn号:

这是redo log的一些信息:

我们主要关注第一次改变编号和状态,我们可以看见,第3号日志组,序列号36的FIRST_CHANGE#和当前数据库的系统scn号一致,为什么呢,FIRST_CHANGE#又是什么呢?从查询结果我们可以看出,1号日志组是最旧的,2号次之,3号是最新的,这是从FIRST_CHANGE#可以看出来的,有FRIST就应该有NEXT啊,其实不难理解,下一个日志组的FIRST_CHANGE#其实就是这当前日志组的NEXT。所以例如1号日知组,FIRST_CHANGE#是1372964,NEXT是1395875。FIRST_CHANGE#的意义是该日志文件的第一条日志内容的scn号,NEXT就是该日志文件的最后一条内容的scn号了。那么如果此时数据库崩溃,数据文件的scn号是1398359,而3号日志文件的FIRST_CHANGE#也是1398359,且当3号日志组的状态是current,恢复就只要恢复3号日志组文件的内容就可以了,因为其他日志文件所记录的内容已写入到数据文件中。
还有一种情况,如果三个日志组的状态是active、active、current,那么数据文件的scn号就会和比较旧的active的日志组的FIRST_CHANGE#一致,这时如果崩溃后恢复,那么三个日志组都会用到。
结论:现在可以理解了,scn号的目的是为了保证数据库状态的一致性,而scn和redo log的FIRST_CHANGE#作用是,当实例恢复的时候,确定了该跑哪个日志组,才能将脏块重现在buffer cache中。而确定日志组后,又该从该日志组的哪条日志开始,就要从控制文件的LRBA中获取了(在我的上一个随笔检查点队列中有描述)。
oracle中scn(系统改变号)的更多相关文章
- Oracle中的不等于号
今天碰到一个Oracle不等于的问题,最后搜索了一下,发现下面资料,拿来跟大家分享一下 关于Oracle中的不等于号: 在Oracle中, <> != ~= ^= 都是不等于号的意思. ...
- 问题:oracle 不等于;结果:Oracle中的不等于号
Oracle中的不等于号 今天碰到一个Oracle不等于的问题,最后搜索了一下,发现下面资料,拿来跟大家分享一下 关于Oracle中的不等于号: 在Oracle中, <> != ~= ...
- 浅析Oracle中的不等于号
前几天碰到一个关于Oracle不等于的问题,最后搜索了一下,发现下面资料,拿来跟大家分享一下,需要的朋友可以参考下 关于Oracle中的不等于号: 在Oracle中, <> != ...
- Oracle的SCN与检查点机制
Oracle的SCN与检查点机制 SCN在Oracle的文档上以多种形式出现,一种是System Change Number,另一种是System Commit Number,在大多数情况下,Syst ...
- Talend 将Oracle中数据导入到hive中,根据系统时间设置hive分区字段
首先,概览下任务图: 流程是,先用tHDFSDelete将hdfs上的文件删除掉,然后将oracle中的机构表中的数据导入到HDFS中:建立hive连接->hive建表->tJava获取系 ...
- Oracle中常用的系统函数
本文主要来梳理下Oracle中的常用的系统函数,掌握这些函数的使用,对于我们编写SQL语句或PL/SQL代码时很有帮助,所以这也是必须掌握的知识点. 本文主要包括以下函数介绍:1.字符串函数2. 数值 ...
- Oracle中的单引号问题
SELECT '<a href="javascript:void(0)" onclick="openWyl('''||a.aac001 FROM ac01 a; S ...
- Oracle中奇怪的【不等于号】
Oracle中奇怪的[不等于号] 在Oracle中,不等号有三种:<>,!=,^= 例如: select * from test where name<>'xn'.返回的结 ...
- 关于Oracle RAC中SCN原理和机制的探索
今天看书时看到了关于RAC中SCN的问题,为了进一步搞清楚其内部原理和机制,对该问题进行了广泛的查阅和搜索,遗憾的是,可以参考的资料很少,网上大部分是人云亦云的帖子,其中,详细介绍其内部原理和机制的资 ...
随机推荐
- Javascript初学篇章_5(对象)
对象 Javascript是一种面向对象的语言,因此可以使用面向对象的思想来进行javascript程序设计对象就是由一些彼此相关的属性和方法集合在一起而构成的一个数据实体.举个例子,一只猫是个对象, ...
- 服务器部署多个tomcat经验
如果想在服务器上部署两个或多个tomcat项目,可以采用多个端口的方法: 如何修改Tomcat端口? 答:在Tomcat的conf文件夹里有个server.xml文件,修改里面的<Conne ...
- Android课程---如何用网格视图做出手机桌面APP
activity_test.xml <?xml version="1.0" encoding="utf-8"?> <GridView xmln ...
- 从网页上抓取Windows补丁信息然后整型输出(Python)
Powershell实现:http://www.cnblogs.com/IvanChen/p/4488246.html 今天通过Python实现: # coding=utf-8 import re i ...
- 2017技术核心——Spring
从毕业从事Java WEB开始到现在已差不多快5年时间了,一直使用的Spring相关的技术,其实最主要的是SpringMVC这一块.其实,一直停留在用的地步,并不知晓其原理,真正耐下心来去研究Spri ...
- 【转】jquery.cookie.js的使用
Cookie是由服务器端生成,发送给User-Agent(一般是浏览器),浏览器会将Cookie的key/value保存到某个目录下的文本文件内,下次请求同一网站时就发送该Cookie给服务器(前提是 ...
- 《UML大战需求分析》阅读笔记03
活动图是用来表达流程的最常见的一种图.活动图与我们之前熟知的流程图相似.而活动图基础语法包含:初始状态.结束状态.活动.状态和合并一般活动图就有一个开始状态.进行活动图绘制的时候需要从总体上规划好业务 ...
- “maven编码gbk的不可映射字符”解决办法
一.问题描述 Eclipse中使用Maven编译项目源代码时,如下的错误 java源代码在Eclipse中显示是没有任何错误的,可是执行"maven install"命令编译项目时 ...
- php usort 按照数组中的某个键值排序
//php usort 按照数组中的某个键值排序 如果第一个参数小于第二个参数 -> 返回小于0的整数如果第一个参数等于于第二个参数 -> 返回等于0的整数如果第一个参数大于于第二个参数 ...
- TestNG
一.TestNG 是什么 ? 脱胎于业界标杆的Junit,并超于Junit,主要原因是由于当时的JUnit3版本不支持annotation,使用不够灵活. TestNG不再需要test前缀的命名方式. ...