故障现象:客户某台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>从 SPFILE 创建 PFILE='D:oracleproduct10.2.0oradatazjportBACKFILEORACLEADMINORCLPFILEINITORCL.ORA';
文件已创建。
添加下面的参数:
undo_management='手动'
_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 SettingsAdministrator>sqlplus / as sysdba
版权所有 (c) 1982、2005,Oracle。 版权所有。
已连接到空闲例程。
SQL>启动 PFILE=D:oracleproduct10.2.0oradatazjportBACKFILEORACLEADMINORCLPFILEINITORCL.ORA MOUNT
ORACLE 例程已经启动。
系统全局区域总计 612368384 字节
固定大小 1250428 字节
可变大小 146803588 字节
数据库缓冲区 457179136 字节
重做缓冲区 7135232 字节
数据库装载完毕。
7、介质恢复
SQL>恢复数据库;
介质完成恢复。
SQL>使用备份控制文件恢复数据库直到取消
D:ORACLEPRODUCT10.2.0FLASH_RECOVERY_AREAZJPORTARCHIVELOG2012_09_20O1_MF_1_145_%U_.ARC
指定日志:{
取消
介质恢复已取消。
SQL>更改数据库打开重置日志;
数据库已更改。
SQL>
-------------------------------------------------------- ----------
至此数据库恢复,服务器空间,后续执行数据备份并写入SPFILE
-------------------------------------------------------- ----------
1、数据库备份
从 pfile='D:oracleproduct10.2.0oradatazjportBACKFILEORACLEADMINORCLPFILEINITORCL.ORA' 创建 spfile;
-------------------------------------------------------- ----------------------------------
至此数据库完全恢复、数据也备份完成,香港虚拟主机,香港虚拟主机,后续修改不归档方式为归档方式
-------------------------------------------------------- ----------------------------------
--归档路径
SQL>更改系统设置 log_archive_dest_1='LOCATION=D:oracleproduct10.2.0oradatazjportarchivelog';
--归档命名格式
SQL>更改系统设置 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;
本文出自 “麦地坞” 博客,请务必保留此出处