导致oracle 控制文件坏,异常断电导致ORACLE控制文件等受到破坏的处理

故障现象:客户某台WINDOWS服务器掉电,ORACLE数据库STARTUP提示控制文件CONTROL01.CTL、CONTROL02.CTL被破坏。一、处理控制文件异常故障方法:直接拷贝CONTROL0

一、处理控制文件异常故障

二、尝试启动

SQL> startup;

ORACLE例程已经启动。

Total System Global Area 612368384 bytes

Fixed Size 1250428 bytes

Variable Size 146803588 bytes

Database Buffers 457179136 bytes

Redo Buffers 7135232 bytes

数据库装载完毕。

SQL> recover database;

完成介质恢复。

SQL> shutdown immediate;

ORA-01109:数据库未打开

已经卸载数据库。

ORACLE例程已经关闭。

SQL> startup;

ORACLE例程已经启动。

Total System Global Area 612368384 bytes

Fixed Size 1250428 bytes

Variable Size 146803588 bytes

Database Buffers 457179136 bytes

Redo Buffers 7135232 bytes

数据库装载完毕。

ORA-00607:当更改数据块时出现内部错误

SQL> SELECT SEGMENT_NAME FROM DBA_ROLLBACK_SEGS;

SEGMENT_NAME

------------------------------

SYSTEM

_SYSSMU1$

_SYSSMU2$

_SYSSMU3$

_SYSSMU4$

_SYSSMU5$

_SYSSMU6$

_SYSSMU7$

_SYSSMU8$

_SYSSMU9$

_SYSSMU10$

SEGMENT_NAME

------------------------------

_SYSSMU11$

_SYSSMU12$

_SYSSMU13$

_SYSSMU14$

_SYSSMU15$

_SYSSMU16$

_SYSSMU17$

_SYSSMU18$

SQL>

SQL> CREATE PFILE='D:\oracle\product\10.2.0\oradata\zjport\BACKFILE\ORACLEADMINORCLPFILEINITORCL.ORA' FROM SPFILE;

文件已创建。

添加下面的参数:

undo_management='MANUAL'

_corrupted_rollback_segments=

(_SYSSMU1&,_SYSSMU2&,_SYSSMU3&,_SYSSMU4&,_SYSSMU5&,_SYSSMU6&,_SYSSMU7&,_SYSSMU8&,_SYSSMU9&,_SYSSMU10&,_SYSSMU11&,_SYSSMU12&,_SYSSMU13&,_SYSSMU14&,_SYSSMU15&,_SYSSMU16&,_SYS

SMU17&,_SYSSMU18&)

C:\Documents and Settings\Administrator>sqlplus / as sysdba

Copyright (c) 1982, 2005, Oracle. All rights reserved.

已连接到空闲例程。

SQL> STARTUP PFILE=D:\oracle\product\10.2.0\oradata\zjport\BACKFILE\ORACLEADMINORCLPFILEINITORCL.ORA MOUNT

ORACLE例程已经启动。

Total System Global Area 612368384 bytes

Fixed Size 1250428 bytes

Variable Size 146803588 bytes

Database Buffers 457179136 bytes

Redo Buffers 7135232 bytes

数据库装载完毕。

7、介质恢复

SQL> RECOVER DATABASE;

完成介质恢复。

SQL> RECOVER DATABASE USING BACKUP CONTROLFILE UNTIL CANCEL

D:\ORACLE\PRODUCT\10.2.0\FLASH_RECOVERY_AREA\ZJPORT\ARCHIVELOG\2012_09_20\O1_MF_1_145_%U_.ARC

指定日志: {=suggested | filename | AUTO | CANCEL}

cancel

介质恢复已取消。

SQL> ALTER DATABASE OPEN RESETLOGS;

数据库已更改。

SQL>

---------------------------------------------------

至此数据库恢复,服务器空间,后续执行数据备份并写入SPFILE

---------------------------------------------------

1、数据库备份

create spfile from pfile='D:\oracle\product\10.2.0\oradata\zjport\BACKFILE\ORACLEADMINORCLPFILEINITORCL.ORA';

---------------------------------------------------------------------------

至此数据库完全恢复、数据也备份完成,香港虚拟主机,香港虚拟主机,后续修改不归档方式为为归档方式

---------------------------------------------------------------------------

--归档路径

SQL> alter system set log_archive_dest_1='LOCATION=D:\oracle\product\10.2.0\oradata\zjport\archivelog';

--归档命名格式

SQL> alter system set log_archive_max_processes = 5;

SQL> alter system set log_archive_format = "archive_%t_%s_%r.arc" scope=spfile;

2、重启数据库

SQL> shutdown immediate

SQL> startup mount;

SQL> alter database archivelog;

SQL> alter database open;

3、确认

SQL> archive log list;

本文出自 “麦地坞” 博客,请务必保留此出处

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值