这篇文章是转载的,其中的部分问题描述与我在windows下的描述不同,但是也是实际解决了我遇到的这个问题的,特此转来,黑体字部分是我的修改。
原文地址:http://www.cnblogs.com/zysblog/archive/2012/04/18/2456150.html
一、原因:windows下oracle服务器因断电关闭。
二、现象:SQL*Plus无法连接,显示以下错误: ORA-01033 : ORACLE initialization or shutdown in progress
三、分析:应该是Oracle在启动后,用户登录时是要将方案中原有配置信息装载进入,装载过程中遇到原有文件指定的位置上没有找到,所以就报出错误。
四、解决过程:
以DBA用户登录,具体命令是
sqlplus /NOLOG
>connect sysdba/sysdba as sysdba
提示:已成功
>shutdown normal
(等了半天没有停掉)
于是执行
>shutdown immediate
提示:数据库已经关闭已经卸载数据库 ORACLE 例程已经关闭
>startup mount
提示:ORACLE例程已经启动
Total System Global Area 118255568 bytes Fixed Size
282576 bytes Variable Size
82886080 bytes Database Buffers
33554432 bytes Redo Buffers
532480 bytes
数据库装载完毕
>alter database open;
提示:第 1 行出现错误: ORA-01157: 无法标识/锁定数据文件7 - 请参阅 DBWR 跟踪文件
ORA-01110: 数据文件 7: ''/opt/oracle/db/oradata/ora232/test01.dbf' 这个提示文件部分根据每个人不同情况有点差别。
继续输入
>alter database datafile 7 offline drop;
提示:数据库已更改。
循环使用最后两步,直到alter database open;后不再提示错误,出现“数据库已更改”。
然后接着输入即可
>shutdown normal
提示:数据库已经关闭已经卸载数据库 ORACLE 例程已经关闭
>startup
提示:ORACLE例程已经启动
Total System Global Area 118255568 bytes Fixed Size
282576 bytes Variable Size
82886080 bytes Database Buffers
33554432 bytes Redo Buffers
532480 bytes
数据库装载完毕
>startup mount
提示:ORACLE例程已经启动
Total System Global Area 118255568 bytes Fixed Size
282576 bytes Variable Size
82886080 bytes Database Buffers
33554432 bytes Redo Buffers
532480 bytes
数据库装载完毕
>alter database open;
提示:第 1 行出现错误: ORA-01157: 无法标识/锁定数据文件7 - 请参阅 DBWR 跟踪文件
ORA-01110: 数据文件 7: ''/opt/oracle/db/oradata/ora232/test01.dbf' 这个提示文件部分根据每个人不同情况有点差别。
继续输入
>alter database datafile 7 offline drop;
提示:数据库已更改。
循环使用最后两步,直到alter database open;后不再提示错误,出现“数据库已更改”。
然后接着输入即可
>shutdown normal
提示:数据库已经关闭已经卸载数据库 ORACLE 例程已经关闭
>startup
提示:ORACLE例程已经启动
Total System Global Area 118255568 bytes Fixed Size
282576 bytes Variable Size
82886080 bytes Database Buffers
33554432 bytes Redo Buffers
532480 bytes
数据库装载完毕
数据库已经打开
至此就可以解决了。完