» 网友学堂 » Mysql教程 » 几种简单的损坏控制文件的恢复方法
几种简单的损坏控制文件的恢复方法
作者:ljjk5 发表时间:2007-6-17 09:07 阅读:295次 在百度搜索相关内容

一、 损坏单个控制文件
  损坏单个控制文件是比较容易恢复的,因为一般的数据库系统,控制文件都不是一个,而且所有的控制文件都互为镜相,只要拷贝一个好的控制文件替换坏的控制文件就可以了。

  1、控制文件损坏,最典型的就是启动数据库出错,不能mount数据库

SQL>startup
  ORA-00205: error in identifying controlfile, check alert log for more info

  查看报警日志文件,有如下信息

alter database mount
  Mon May 26 11:59:52 2003
  ORA-00202: controlfile: 'D:Oracleoradatachencontrol01.ctl'
  ORA-27041: unable to open file
  OSD-04002: unable to open file
  O/S-Error: (OS 2)

  系统找不到指定的文件。

  2、停止数据库

SQL>shutdown immediate

  3、拷贝一个好的控制文件替换坏的控制文件或修改init.ora中的控制文件参数,取消这个坏的控制文件。

  4、重新启动数据

SQL>startup

  说明:

  1、损失单个控制文件是比较简单的,因为数据库中所有的控制文件都是镜相的,只需要简单的拷贝一个好的就可以了

  2、建议镜相控制文件在不同的磁盘上

  3、建议多做控制文件的备份,长期保留一份由alter database backup control file to trace产生的控制文件的文本备份

  二、 损坏全部控制文件

  损坏多个控制文件,或者人为的删除了所有的控制文件,通过控制文件的复制已经不能解决问题,这个时候需要重新建立控制文件。同时注意,alter database backup control file to trace可以产生一个控制文件的文本备份。

  以下是详细重新创建控制文件的步骤

  1、关闭数据库

SQL>shutdown immediate;

  2、删除所有控制文件,模拟控制文件的丢失

  3、启动数据库,出现错误,并不能启动到mount下

SQL>startup
  ORA-00205: error in identifying controlfile, check alert log for more info

  查看报警日志文件,有如下信息

alter database mount
  Mon May 26 11:53:15 2003
  ORA-00202: controlfile: 'D:Oracleoradatachencontrol01.ctl'
  ORA-27041: unable to open file
  OSD-04002: unable to open file
  O/S-Error: (OS 2)

  系统找不到指定的文件。

#Advertisement