最近学习oracle数据库,遇到了这个错误:
ORA-01033: ORACLE initialization or shutdown in progress
故障特征:使用命令行sqlplus或PL/SQL Developer均无法打开数据库。但是可以使用sys用户以sysdba的身份登录系统产生的原因是: 卸载上一个版本的数据库时,有些文件没有卸载干净。
第一次按照别人的指导在cmd中 以sys用户登录,然后依次输入以下代码:
recover database using backup controlfile;
C:\oracle\product\10.2.0\oradata\orcl\REDO01.LOG(该路径是安装oracle的路径,每个人的可能不一样,我是默认安装到C盘的。)
recover database using backup controlfile;
C:\oracle\product\10.2.0\oradata\orcl\REDO02.LOGalter database open resetlogs;
处理成功了。
结果第二天还是遇到了这个错误,但是按照上面的操作不能解决。自己在网上搜索了一些解决办法,因为每个人出现的情况不一样,所以显示的内容也不一样,我结合了其他人的解决办法将处理过程整理了一下。
处理步骤:1. 在 ‘开始’-->‘运行’执行cmd
2.输入 sqlplus
再输入: SQL>sys/as sysdba 应提示类似于如下信息:SQL*Plus: Release 10.2.0.1.0 - Production on 星期日 9月 26 20:06:13 2010
Copyright (c) 1982, 2005, Oracle. All rights reserved.
连接到: Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production With the Partitioning, OLAP and Data Mining options3.输入SQL> shutdown immediate
ORA-01109: 数据库未打开 已经卸载数据库。 ORACLE 例程已经关闭。 4.输入SQL> startup ORACLE 例程已经启动。Total System Global Area 612368384 bytes
Fixed Size 1250428 bytes Variable Size 230689668 bytes Database Buffers 373293056 bytes Redo Buffers 7135232 bytes 数据库装载完毕。 ORA-01589: 要打开数据库则必须使用 RESETLOGS 或 NORESETLOGS 选项5.SQL> alter database open resetlogs;
alter database open resetlogs * 第 1 行出现错误: ORA-01194: 文件 1 需要更多的恢复来保持一致性 ORA-01110: 数据文件 1: 'C:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\SYSTEM01.DBF'6.SQL> recover database using backup controlfile;
ORA-00283:恢复会话因错误而取消
ORA-19909:数据文件6 属于孤立的原型 ORA-01110:数据文件6:'D:\MYTS.DBF'7.SQL> alter database datafile 'D:\MYTS.DBF' offline drop;
数据库已更改。 从步骤3开始继续按照刚才的方法进行,步骤如下:SQL> shutdown immediate
ORA-01109: 数据库未打开 已经卸载数据库。 ORACLE 例程已经关闭。 SQL> startup ORACLE 例程已经启动。Total System Global Area 612368384 bytes
Fixed Size 1250428 bytes Variable Size 230689668 bytes Database Buffers 373293056 bytes Redo Buffers 7135232 bytes 数据库装载完毕。 ORA-01589: 要打开数据库则必须使用 RESETLOGS 或 NORESETLOGS 选项SQL> alter database open resetlogs;
alter database open resetlogs * 第 1 行出现错误: ORA-01194: 文件 1 需要更多的恢复来保持一致性 ORA-01110: 数据文件 1: 'C:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\SYSTEM01.DBF'SQL> recover database using backup controlfile;
ORA-00279: 更改 575807 (在 08/23/2012 14:13:16 生成) 对于线程 1 是必需的 ORA-00289: 建议: C:\ORACLE\PRODUCT\10.2.0\FLASH_RECOVERY_AREA\ORCL\ARCHIVELOG\2012_08_28\01_MF _1_3_%u_.ARC ORA-00280: 更改 575807 用于线程 1 在序列 # 3 中 指定日志: {<RET>=suggested | filename | AUTO | CANCEL} C:\oracle\product\10.2.0\oradata\orcl\REDO01.LOG !!!输入此文件路径 ORA-00310:归档日志包含序列2;要求序列3 ORA-00334:归档日志:'C:\oracle\product\10.2.0\oradata\orcl\REDO01.LOG'SQL> recover database using backup controlfile;
ORA-00279: 更改 575807 (在 08/23/2012 14:13:16 生成) 对于线程 1 是必需的 ORA-00289: 建议: C:\ORACLE\PRODUCT\10.2.0\FLASH_RECOVERY_AREA\ORCL\ARCHIVELOG\2012_08_28\01_MF _1_3_%u_.ARC ORA-00280: 更改 575807 用于线程 1 在序列 # 3 中指定日志: {<RET>=suggested | filename | AUTO | CANCEL}
C:\oracle\product\10.2.0\oradata\orcl\REDO02.LOG !!!输入此文件路径 已应用的日志。 完成介质恢复。 SQL> alter database open resetlogs; 数据库已更改。在PL/SQL中如果能够顺利登录就可以啦。