当前位置:  数据库>oracle

Oracle手工恢复控制文件的深入解析

    来源: 互联网  发布时间:2017-05-22

    本文导语:       v$database.CHECKPOINT_CHANGE#  (last scn checkpointed)      v$database.CONTROLFILE_SEQUENCE# (control file sequence number incremented by control file transactions)      v$database.CONTROLFILE_CHANGE# (last scn in backup control file ;null if the control file is not a backup)     ...

      v$database.CHECKPOINT_CHANGE#  (last scn checkpointed)
      v$database.CONTROLFILE_SEQUENCE# (control file sequence number incremented by control file transactions)
      v$database.CONTROLFILE_CHANGE# (last scn in backup control file ;null if the control file is not a backup)
      v$datafile.CHECKPOINT_CHANGE#  (scn at last checkpoint)
      v$datafile_header. CHECKPOINT_CHANGE# (datafile checkpoint change#
      v$log.FIRST_CHANGE# (lowest system change number(SCN) in the log
 
v$database.CHECKPOINT_CHANGE# 代表是数据库最后一次进行完全检查点的scn号。只有在进行完全检查点的时候才进行更新,更新的值为当前现在数据库的current_scn值。
 v$database.CONTROLFILE_CHANGE# (代表从备份中恢复过来的控制文件的最后一个scn号假如是刚刚从备份中恢复,如果控制文件不是从备份中恢复过来的,那么该值为null,但是当控制文件在数据库打开的时候,那么该值会随着增量检查点和完全检查点或是数据库结构变化时会设置为当下的current_scn值。
 
SYS@orcl#select CHECKPOINT_CHANGE#,CONTROLFILE_SEQUENCE#,CONTROLFILE_CHANGE# from v$database;
 
CHECKPOINT_CHANGE# CONTROLFILE_SEQUENCE# CONTROLFILE_CHANGE#
 ------------------ --------------------- -------------------
            4921905                14285            4922868
 23:13:45 SYS@orcl#select CHECKPOINT_CHANGE#,CONTROLFILE_SEQUENCE#,CONTROLFILE_CHANGE# from v$database;
 
CHECKPOINT_CHANGE# CONTROLFILE_SEQUENCE# CONTROLFILE_CHANGE#
 ------------------ --------------------- -------------------
            4935440                14311            4935548
 
23:13:46 SYS@orcl#select current_scn from v$database;
 
CURRENT_SCN
 -----------
    4935575
 
23:13:46 SYS@orcl#alter system checkpoint;
 select CHECKPOINT_CHANGE#,CONTROLFILE_SEQUENCE#,CONTROLFILE_CHANGE# from v$database;
 系统已更改。
 
23:13:46 SYS@orcl#
 
CHECKPOINT_CHANGE# CONTROLFILE_SEQUENCE# CONTROLFILE_CHANGE#
 ------------------ --------------------- -------------------
            4935576                14313            4935578
 
23:13:49 SYS@orcl#
 23:14:09 SYS@orcl#select CHECKPOINT_CHANGE#,CONTROLFILE_SEQUENCE#,CONTROLFILE_CHANGE# from v$database;
 
CHECKPOINT_CHANGE# CONTROLFILE_SEQUENCE# CONTROLFILE_CHANGE#
 ------------------ --------------------- -------------------
            4935576                14314            4935649
 
23:16:42 SYS@orcl#alter system switch logfile;
 
系统已更改。
 
23:16:52 SYS@orcl#select CHECKPOINT_CHANGE#,CONTROLFILE_SEQUENCE#,CONTROLFILE_CHANGE# from v$database;
 
CHECKPOINT_CHANGE# CONTROLFILE_SEQUENCE# CONTROLFILE_CHANGE#
 ------------------ --------------------- -------------------
            4935576                14318            4935675
 
23:16:55 SYS@orcl#
 
v$database.CONTROLFILE_SEQUENCE# (代表根据数据库的变化进行增加的序列,在查询的时候显示的是当前的控制文件是在哪个sequence号,随着增量检查点和完全检查点或是数据库结构变化而incremental。
 
v$datafile.CHECKPOINT_CHANGE#  (这个值代表的是数据文件中最后一个last checkpoint 的scn号与v$database 中的CHECKPOINT_CHANGE#相同。也就是说当进行完全检查点的时候,需要数据文件中的scn和控制文件中的scn保持一致性。当我们启动到数据库mount状态下然后dump数据文件看到的checkpoint scn正是这个值,在进行数据库启动要验证该值)
 23:26:05 SYS@orcl#select CHECKPOINT_CHANGE#,CONTROLFILE_SEQUENCE#,CONTROLFILE_CHANGE# from v$database;
 
CHECKPOINT_CHANGE# CONTROLFILE_SEQUENCE# CONTROLFILE_CHANGE#
 ------------------ --------------------- -------------------
            4935675                14332            4937039
 
23:26:30 SYS@orcl#select checkpoint_change# from v$datafile;
 
CHECKPOINT_CHANGE#
 ------------------
            4935675
            4935675
            4935675
            4935675
            4935675
            4935675
            4935675
            4935675
            4935675
            4935675
            4935675
 
CHECKPOINT_CHANGE#
 ------------------
            4935675
 
已选择12行。
 
23:26:31 SYS@orcl#alter system checkpoint;
 
系统已更改。
 
23:27:27 SYS@orcl#select CHECKPOINT_CHANGE#,CONTROLFILE_SEQUENCE#,CONTROLFILE_CHANGE# from v$database;
 
CHECKPOINT_CHANGE# CONTROLFILE_SEQUENCE# CONTROLFILE_CHANGE#
 ------------------ --------------------- -------------------
            4937086                14336            4937088
 
23:27:31 SYS@orcl#select checkpoint_change# from v$datafile;
 
CHECKPOINT_CHANGE#
 ------------------
            4937086
            4937086
            4937086
            4937086
            4937086
            4937086
            4937086
            4937086
            4937086
            4937086
            4937086
 
CHECKPOINT_CHANGE#
 ------------------
            4937086
 
已选择12行。
 
23:27:32 SYS@orcl#
 v$datafile_header. CHECKPOINT_CHANGE# (代表数据文件头的检查点scn,这个值和数据文件的检查点相一致,在数据库运行到open状态进行的数据文件dump文件中的header 中的checkpoint scn就是此值。)

    
 
 

您可能感兴趣的文章:

  • Oracle新手教程 手工创建数据库的全部脚本及说明
  • 高手救命,很急——ORACLE817安装在UNIXWARE711上,手工启动数据库后在netasst中连接错误,高手帮我看看?
  • [小技巧]手工扩大Oracle数据库表空间的方法
  • Oracle数据库手工扩大表空间的方法
  • ORACLE DATAGUARD中手工处理日志v$archive_GAP的方法
  • Oracle中手工创建数据库的全部脚本与说明
  • Oracle11.2 命令行手工最简创建数据库的过程
  • Linux下Oracle手工建库过程
  • 手工创建Oracle数据库控制文件的策略
  • 手工配置Oracle 10G Enterprise Manager过程
  • 在Oracle中手工对任务进行分区的方法
  • linux下oracle的自启动脚本解析
  • oracle SQL解析步骤小结
  • 解析mysql与Oracle update的区别
  • 解析Oracle查询和删除JOB的SQL iis7站长之家
  • 深入解析Oracle参数及参数文件
  • Oracle数据库安装配置流程示例详细解析
  • Oracle中DBMS_SQL解析SQL语句的流程
  • [Oracle] RAC 之 - 负载均衡深入解析
  • Oracle数据库安全性管理基本措施实例解析
  • 解析Oracle查询和删除JOB的SQL
  • 解析jdbc处理oracle的clob字段的详解
  • 职场专家解析Oracle认证门道
  • oracle 索引不能使用深入解析
  • oracle的rownum深入解析
  • 解析如何查看Oracle数据库中某张表的字段个数
  • Oracle row_number() over()解析函数高效实现分页
  • 解析学习Oracle架构所应了解的基础知识
  • Oracle基本查询过滤排序示例解析
  • Oracle硬解析和软解析的区别分析
  • 解析Oracle中多表级联删除的方法
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 深入oracle特定信息排序的分析
  • 深入理解Oracle数据库的启动和关闭
  • oracle导出sql语句的结果集和保存执行的sql语句(深入分析)
  • 深入探讨:Oracle中如何查询正锁表的用户以及释放被锁的表的方法
  • Oracle表连接深入浅出
  • 深入剖析哪些服务是Oracle 11g必须开启的
  • 深入分析关于Oracle数据库的备份策略
  • Oracle 9i数据库中动态重配置深入分析
  • 深入ORACLE变量的定义与使用的详解
  • oracle日期时间型timestamp的深入理解
  • Oracle中RAISE异常深入分析
  • 深入Oracle的left join中on和where的区别详解
  • 深入探讨:oracle中row_number() over()分析函数用法
  • 深入ORACLE迁移到MYSQL的总结分析
  • 深入oracle分区索引的详解
  • 深入sql oracle递归查询
  • oracle 索引组织表的深入详解
  • 深入探讨:oracle中方案的概念以及方案与数据库的关系
  • ORACLE时间函数(SYSDATE)深入理解
  • 基于oracle中锁的深入理解
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,