在学习群里有个同学误删除了控制文件,于是我也把自己数据库的控制文件删除了,看看能不能进行恢复,以下是整个实验的过程~~在做之前,先看看控制文件的备份方式:
1.生成可以重建控制文件的脚本。
2.备份二进制的控制文件。

我们这次着重来看看第1种方式。
        查看控制文件,发现我自己只有一个控制文件,记得老师说过,有些数据库有好几个控制文件,每个控制文件的内容都是一样的,如果一个丢了或者坏了,从别的控制文件拷贝复制下就ok,结果我只有一个,不能使用这种方式进行恢复了,只能通过重建控制文件的方式来修复。
        如何获得重建控制文件的脚本呢?

SQL> select status from v$instance;

STATUS
------------
OPEN SQL> alter database backup controlfile to trace; 数据库已更改。 SQL> select d.value||b.bias||lower(rtrim(i.instance, chr(0)))||'_ora_'||p.spid|
|'.trc' trace_file_name from ( select p.spid from sys.v$mystat m,sys.v$session s
,sys.v$process p where m.statistic# = 1 and s.sid = m.sid and p.addr = s.paddr)
p, ( select t.instance from sys.v$thread t,sys.v$parameter v where v.name = 'thr
ead' and (v.value = 0 or t.thread# = to_number(v.value))) i, ( select value from
sys.v$parameter where name = 'user_dump_dest') d,(select DECODE(count(BANNER),0
,'/','\') bias from v$version where upper(banner) like '%WINDOWS%') b; TRACE_FILE_NAME
-------------------------------------------------------------------------------- d:\app\fx\diag\rdbms\orcl\orcl\trace\orcl_ora_3800.trc

  

以上两个语句,就能获得控制文件的生成语句和该语句所在的位置啦~~我们现在过去看看这个创建语句长什么样?在上述路径下,我们顺利找到了该文件,在文件中,我们发现了以下内容,黑色加粗部分就是我们需要的创建控制文件的语句了~
STARTUP NOMOUNT
CREATE CONTROLFILE REUSE DATABASE "ORCL" NORESETLOGS  ARCHIVELOG
    MAXLOGFILES 16
    MAXLOGMEMBERS 3
    MAXDATAFILES 100
    MAXINSTANCES 8
    MAXLOGHISTORY 292
LOGFILE
  GROUP 1 'D:\APP\FX\ORADATA\ORCL\REDO01.LOG'  SIZE 50M BLOCKSIZE 512,
  GROUP 2 'D:\APP\FX\ORADATA\ORCL\REDO02.LOG'  SIZE 50M BLOCKSIZE 512,
  GROUP 3 'D:\APP\FX\ORADATA\ORCL\REDO03.LOG'  SIZE 50M BLOCKSIZE 512,
  GROUP 4 'D:\APP\FX\ORADATA\ORCL\REDO04.LOG'  SIZE 50M BLOCKSIZE 512
-- STANDBY LOGFILE
DATAFILE
  'D:\APP\FX\ORADATA\ORCL\SYSTEM01.DBF',
  'D:\APP\FX\ORADATA\ORCL\SYSAUX01.DBF',
  'D:\APP\FX\ORADATA\ORCL\UNDOTBS01.DBF',
  'D:\APP\FX\ORADATA\ORCL\USERS01.DBF',
  'D:\APP\FX\ORADATA\ORCL\EXAMPLE01.DBF',
  'D:\APP\FX\ORADATA\ORCL\UNDOTBS02.DBF',
  'D:\APP\FX\ORADATA\ORCL\USERS02.DBF',
  'D:\APP\FX\ORADATA\ORCL\USERS04.DBF',
  'D:\APP\FX\ORADATA\ORCL\USERS06.DBF'
CHARACTER SET ZHS16GBK
;
-- Commands to re-create incarnation table
-- Below log names MUST be changed to existing filenames on
-- disk. Any one log file from each branch can be used to
-- re-create incarnation records.
-- ALTER DATABASE REGISTER LOGFILE 'D:\APP\FX\FLASH_RECOVERY_AREA\ORCL\ARCHIVELOG\2014_01_20\O1_MF_1_1_%U_.ARC';
-- ALTER DATABASE REGISTER LOGFILE 'D:\APP\FX\FLASH_RECOVERY_AREA\ORCL\ARCHIVELOG\2014_01_20\O1_MF_1_1_%U_.ARC';
-- Recovery is required if any of the datafiles are restored backups,
-- or if the last shutdown was not normal or immediate.
RECOVER DATABASE
-- All logs need archiving and a log switch is needed.
ALTER SYSTEM ARCHIVE LOG ALL;
-- Database can now be opened normally.
ALTER DATABASE OPEN;

现在创建语句已经有了,我们就开始试验吧~~
1、我们先关闭数据库,将控制文件删除,分阶段启动数据库,先是到nomount,这个阶段需要参数文件,不需要控制文件,启动应该没问题:

SQL> startup nomount;
ORACLE 例程已经启动。 Total System Global Area 535662592 bytes
Fixed Size 1375792 bytes
Variable Size 285213136 bytes
Database Buffers 243269632 bytes
Redo Buffers 5804032 bytes
SQL> select status from v$instance; STATUS
------------------------
STARTED

  

2、接下来,启动到mount状态肯定就不行啦,因为我们已经把控制文件给删除啦~~既然这样,我们就要尝试进行控制文件的重建了~把上文中的创建语句在sys用户下执行一下吧~~

SQL> alter database mount;
alter database mount
*
第 1 行出现错误:
ORA-00205: ?????????, ??????, ??????? SQL> CREATE CONTROLFILE REUSE DATABASE "ORCL" NORESETLOGS ARCHIVELOG
2 MAXLOGFILES 16
3 MAXLOGMEMBERS 3
4 MAXDATAFILES 100
5 MAXINSTANCES 8
6 MAXLOGHISTORY 292
7 LOGFILE
8 GROUP 1 'D:\APP\FX\ORADATA\ORCL\REDO01.LOG' SIZE 50M BLOCKSIZE 512,
9 GROUP 2 'D:\APP\FX\ORADATA\ORCL\REDO02.LOG' SIZE 50M BLOCKSIZE 512,
10 GROUP 3 'D:\APP\FX\ORADATA\ORCL\REDO03.LOG' SIZE 50M BLOCKSIZE 512,
11 GROUP 4 'D:\APP\FX\ORADATA\ORCL\REDO04.LOG' SIZE 50M BLOCKSIZE 512
12 DATAFILE
13 'D:\APP\FX\ORADATA\ORCL\SYSTEM01.DBF',
14 'D:\APP\FX\ORADATA\ORCL\SYSAUX01.DBF',
15 'D:\APP\FX\ORADATA\ORCL\UNDOTBS01.DBF',
16 'D:\APP\FX\ORADATA\ORCL\USERS01.DBF',
17 'D:\APP\FX\ORADATA\ORCL\EXAMPLE01.DBF',
18 'D:\APP\FX\ORADATA\ORCL\UNDOTBS02.DBF',
19 'D:\APP\FX\ORADATA\ORCL\USERS02.DBF',
20 'D:\APP\FX\ORADATA\ORCL\USERS04.DBF',
21 'D:\APP\FX\ORADATA\ORCL\USERS06.DBF'
22 CHARACTER SET ZHS16GBK
23 ; 控制文件已创建。 SQL>

  

3、噢耶~~控制文件重建好了~~我们打开数据库试试~

SQL> ALTER DATABASE OPEN;

数据库已更改。

  

数据库打开了,我的数据库是归档模式,我重建了控制文件之后,需要再次对数据库进行备份。
如果还没有来得及生成重建控制文件的脚本,控制文件就坏了,那我们可以仿写这个重建语句,把自己数据库的相关信息填进去,一个崭新的重建语句就诞生啦~~~
CREATE CONTROLFILE REUSE DATABASE "ORCL" NORESETLOGS  ARCHIVELOG  ----数据库名称
    MAXLOGFILES 16
    MAXLOGMEMBERS 3
    MAXDATAFILES 100
    MAXINSTANCES 8
    MAXLOGHISTORY 292
LOGFILE
  GROUP 1 'D:\APP\FX\ORADATA\ORCL\REDO01.LOG'  SIZE 50M BLOCKSIZE 512,   -----日志文件组和路径信息
  GROUP 2 'D:\APP\FX\ORADATA\ORCL\REDO02.LOG'  SIZE 50M BLOCKSIZE 512,
  GROUP 3 'D:\APP\FX\ORADATA\ORCL\REDO03.LOG'  SIZE 50M BLOCKSIZE 512,
  GROUP 4 'D:\APP\FX\ORADATA\ORCL\REDO04.LOG'  SIZE 50M BLOCKSIZE 512
-- STANDBY LOGFILE
DATAFILE
  'D:\APP\FX\ORADATA\ORCL\SYSTEM01.DBF',          -----数据文件信息
  'D:\APP\FX\ORADATA\ORCL\SYSAUX01.DBF',
  'D:\APP\FX\ORADATA\ORCL\UNDOTBS01.DBF',
  'D:\APP\FX\ORADATA\ORCL\USERS01.DBF',
  'D:\APP\FX\ORADATA\ORCL\EXAMPLE01.DBF',
  'D:\APP\FX\ORADATA\ORCL\UNDOTBS02.DBF',
  'D:\APP\FX\ORADATA\ORCL\USERS02.DBF',
  'D:\APP\FX\ORADATA\ORCL\USERS04.DBF',
  'D:\APP\FX\ORADATA\ORCL\USERS06.DBF'
CHARACTER SET ZHS16GBK
;

oracle控制文件丢失恢复的更多相关文章

  1. Oracle控制文件丢失,日志文件丢失

    控制文件丢失: alter database backup controlfile to traces; shutdown immediate; @j:\db\script\orcl_ora_ctl_ ...

  2. RMAN - "丢失控制文件的恢复"

    OS: Oracle Linux Server release 5.7 DB: Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - ...

  3. RMAN备份之丢失数据文件及控制文件的恢复

    About Recovery with a Backup Control FileIf all copies of the current control file are lost or damag ...

  4. oracle控制文件问题

    下午时连接数据库突然发现连不上了,监听报错找不到服务,于是登录数据库所在服务器,查看监听状态,oracle:lsnrctl status 监听状态正常,登入数据库查看[oracle@frkdb1 ~] ...

  5. Oracle控制文件

    一.Oracle 控制文件 为二进制文件,初始化大小由CREATE DATABASE指定,可以使用RMAN备份 记录了当前数据库的结构信息,同时也包含数据文件及日志文件的信息以及相关的状态,归档信息等 ...

  6. Oracle 控制文件(CONTROLFILE)

    一.Oracle 控制文件 为二进制文件,初始化大小由CREATE DATABASE指定,可以使用RMAN备份 记录了当前数据库的结构信息,同时也包含数据文件及日志文件的信息以及相关的状态,归档信息等 ...

  7. Oracle 控制文件损坏解决方案

    Oracle 控制文件损坏解决方案 故障一:丢失(损坏)一个控制文件 前台报错:ORA-00205:error in identifying control file,check alert log ...

  8. Oracle控制文件多路复用以及Oracle备份重建控制文件

    控制文件中记录了oracle数据库的物理结构,也就是记录了数据库数据文件和日志文件的位置,控制文件中还记录了多种SCN,用这些SCN来确定数据文件和日志文件是否是正确的.如果不正确那么数据库就需要恢复 ...

  9. Oracle控制文件操作

    控制文件是连接instance和 database的纽带.记录了database的结构信息. 控制文件是1个2进制文件.记录的是当前database的状态. 控制文件可以有多个,在参数文件中通过con ...

随机推荐

  1. java 多线程—— 线程等待与唤醒

    java 多线程 目录: Java 多线程——基础知识 Java 多线程 —— synchronized关键字 java 多线程——一个定时调度的例子 java 多线程——quartz 定时调度的例子 ...

  2. android 中 webview 怎么用 localStorage?

    我在 android里面 使用html5的 localStorage 为什么存不进去也读不出来呀? 网上搜了好多都没效果 1 2 3 4 5 6 7 8 9 mainWebView = (WebVie ...

  3. 使用ueditor中的setContent() 时经常报innerHtml错误(笔记)

    1)今天遇到个问题,使用ueditor中的setContent() 时经常报innerHtml错误:网上找了下解决方案:发现这个可以用: 不能创建editor之后马上使用ueditor.setCont ...

  4. 基于TF-IDF值的汉语语义消歧算法

    RT,学校课题需要233,没了 话说,窝直接做个链接的集合好了,方便以后查找 特征值提取之 -- TF-IDF值的简单介绍 汉语语义消歧之 -- 句子相似度 汉语语义消歧之 -- 词义消歧简介 c++ ...

  5. .htaccess更改目录下的默认主页

    我们知道apache的配置文件httpd.conf可以配置网站目录的默认主页.配置文件该部分定义如下: #DirectoryIndex: sets the file that Apache will ...

  6. EXE捆绑器

    释放的方法真没想到  太神奇了 // 文件捆绑器Dlg.cpp : 实现文件 // #include "stdafx.h" #include "文件捆绑器.h" ...

  7. Masonry使用注意篇

    简要 自动布局最重要的是约束:UI元素间关系的数学表达式.约束包括尺寸.由优先级和阈值管理的相对位置.它们是添加剂,可能导致约束冲突 .约束不足造成布局无法确定 .这两种情况都会产生异常. 使用前:A ...

  8. uboot 各种烧写命令

    norflash 烧写 (7) Nor Flash指令 Nor Flash 的命令经常用于烧写数据到Nor Flash . flinfo  打印Flash存储器的信息,并列出所有Sector. fli ...

  9. 由ArrayList构造函数源码引出的问题

    ArrayList应该用得很多了.最近看了看其源码,发现有很多细节,如果要我们自己来实现,估计会考虑不到.当然,这些细节跟jdk本身一些实现的bug有关,如果不去深挖,定然是不能发现.本文从Array ...

  10. 系统不支持curl

    解决安装pinphp时出现的“系统不支持curl!”   今天在本机安装phppin开源程序时,提示“系统不支持curl!”错误. 由于我本机是UBUNTU系统,所以直接通过apt-get进行安装. ...