oracle 控制文件损坏时的恢复

数据库只能启动实例,读控制文件时发生错误,控制文件未备份。在数据库设计的过程中,从安全的角度考虑,系统使用了三个径向的控制文件,现在三个控制文件 version 号不一致。
SVRMGRL>startup
oracle instance started
total system global area 222323980 bytes
fixed size 70924 bytes
variable size 78667776 bytes
database buffers 143507456 bytes
redo buffers 77824 bytes
ORA-00214: controlfile ‘d:/oracle/oradata/orcl/control01.ctl’ version 57460 inconsistent with file ‘d:/oracle/oradata/orcl/control02.ctl’ version 57452.
根据以上分析,我们试着修改参数文件。将参数文件中的 control_file 参数修改为一个控制文件,分别使用 control01 control02 control03 。但数据库都无法启动,说明三个控制文件都已损坏。
由于没有控制文件的备份,我们只能采取重建控制文件的做法。
D:/>svrmgrl
Oracle Server Manager Release 3.1.6.0.0 - Production
版权所有 (c) 1997 1999 Oracle Corporation 。保留所有权利。
Oracle8i Enterprise Edition Release 8.1.6.0.0 - Production
With the Partitioning option
JServer Release 8.1.6.0.0 - Production
SVRMGR> connect internal
连接成功。
SVRMGR> shutdowm abort
已关闭 ORACLE 实例。
SVRMGR> startup nomount
已启动 ORACLE 实例。
系统全局区域合计有 108475660 个字节
Fixed Size 70924
个字节
Variable Size 46116864
个字节
Database Buffers 62210048
个字节
Redo Buffers 77824
个字节
SVRMGR>create controlfile reuse database orcl noresetlogs archivelog
Logfile group 1 ‘d:/oracle/oradata/orcl/redo01.log’,
group 2 ‘d:/oracle/oradata/orcl/redo02.log’,
group 3 ‘d:/oracle/oradata/orcl/redo03.log’
datafile ‘d:/oracle/oradata/orcl/system01.dbf’,
‘d:/oracle/oradata/orcl/users01.dbf’,
‘d:/oracle/oradata/orcl/temp01.dbf’,
‘d:/oracle/oradata/orcl/tools01.dbf’,
‘d:/oracle/oradata/orcl/indx01.dbf’,
‘d:/oracle/oradata/orcl/dr01.dbf’,
‘d:/oracle/oradata/orcl/rbs01.dbf’;
语句已处理。
成功地重建控制文件后,我们尝试着打开数据库,但系统报错,提示需要进行介质恢复。
SVRMGR>recover datafile ‘d:/oracle/oradata/orcl/system01.dbf’;
介质已恢复。
SVRMGR> recover datafile ‘d:/oracle/oradata/orcl/users0101.dbf’;
介质已恢复。
SVRMGR> recover datafile ‘d:/oracle/oradata/orcl/temp01.dbf’;
介质已恢复。
SVRMGR> recover datafile ‘d:/oracle/oradata/orcl/tools01.dbf’;
介质已恢复。
SVRMGR> recover datafile ‘d:/oracle/oradata/orcl/indx01.dbf’;
介质已恢复。
SVRMGR> recover datafile ‘d:/oracle/oradata/orcl/dr01.dbf’;
介质已恢复。
SVRMGR> recover datafile ‘d:/oracle/oradata/orcl/rbs01.dbf’;
介质已恢复。
介质恢复后,重新打开数据库,提示日志文件也需恢复。
SVRMGR> recover database until cancel;
日志已恢复。
控制文件、数据文件、日志文件全部恢复后,将三种文件同步,并打开数据库,成功地完成了数据库的恢复工作。
SVRMGR> alter database open resetlogs;
数据库已更改。
立即关闭数据库,并进行数据库的冷备份,将数据库的数据完整地保存下来。 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值