测试9——为何在数据库在mount阶段可以查询v$datafile_header 视图-阿里云开发者社区

开发者社区> 数据库> 正文
登录阅读全文

测试9——为何在数据库在mount阶段可以查询v$datafile_header 视图

简介: 大家都知道只有当数据库进入到OPEN状态时,数据文件才被打开,才能读取其中的内容.那在mount状态下,就可以读取v$datafile_header中的信息,为什么呢? 这说明当从nomount状态进入mount状态时,还是扫描了一下数据文件头中的内容的,而且将相应的信息存储到了控制文件中(因为有网友说通过dump control file可以看到http://www.itpub.net/thread-1153987-1-1.html)。

大家都知道只有当数据库进入到OPEN状态时,数据文件才被打开,才能读取其中的内容.那在mount状态下,就可以读取v$datafile_header中的信息,为什么呢?

这说明当从nomount状态进入mount状态时,还是扫描了一下数据文件头中的内容的,而且将相应的信息存储到了控制文件中(因为有网友说通过dump control file可以看到http://www.itpub.net/thread-1153987-1-1.html)。

我试着做了一个实验,首先,把所有数据文件全部移走,然后mount数据库:

SQL> startup mount;
ORACLE instance started.


Total System Global Area 1653518336 bytes
Fixed Size    2228904 bytes
Variable Size  956304728 bytes
Database Buffers  687865856 bytes
Redo Buffers    7118848 bytes
Database mounted.
SQL> select checkpoint_change#,checkpoint_time from v$datafile_header;


CHECKPOINT_CHANGE# CHECKPOIN
------------------ ---------
0
0
0
0

发现此时,已经读取不到数据文件头部的checkpoint_change#,checkpoint_time等信息。因为没有数据文件可以供扫描了。

然后我又把数据文件移动回来,再重新mount,就可以看到啦:

SQL> shutdown abort
ORACLE instance shut down.
SQL> startup mount;
ORACLE instance started.


Total System Global Area 1653518336 bytes
Fixed Size    2228904 bytes
Variable Size  956304728 bytes
Database Buffers  687865856 bytes
Redo Buffers    7118848 bytes
Database mounted.
SQL> select checkpoint_change#,checkpoint_time from v$datafile_header;


CHECKPOINT_CHANGE# CHECKPOIN
------------------ ---------
  1104824 27-OCT-14
  1104824 27-OCT-14
  1104824 27-OCT-14
  1104824 27-OCT-14


顺便总结下,到底什么时候需要进行数据恢复:

在数据库启动的时候,会检查v$database视图,v$datafile视图,v$datafile_header视图 里的checkpoint_change#,当然这三个视图的数值来源是不同的。v$database视图,v$datafile视图 里的scn是来自控制文件的,而v$datafile_header视图 里的scn是来自数据文件头的。

所以当数据库启动的时候,如果发现v$datafile_header的scn小于v$database(或v$datafile)里的值,就需要进行实例或者介质恢复。


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
数据库
使用钉钉扫一扫加入圈子
+ 订阅

分享数据库前沿,解构实战干货,推动数据库技术变革

其他文章
最新文章
相关文章