Oracle误删数据文件后出现oracle initialization or shutdown in progress解决

一如既往、错误分析

  1、首先我在出现这种情况的背景是实践如下SQL语句后生成的表空间

 1 --自定义表空间    数据表空间  临时表空间
 2 CREATE TEMPORARY TABLESPACE HOUSE_TEMP
 3          TEMPFILE 'D:\OracleData\HOUSE_TEMP.DBF'
 4          SIZE 32M
 5          AUTOEXTEND ON
 6          NEXT 32M 
 7          MAXSIZE 2G
 8          EXTENT MANAGEMENT LOCAL;
 9          
10 CREATE TABLESPACE HOUSE_DATA
11          LOGGING
12          DATAFILE 'D:\OracleData\HOUSE_DATA.DBF'
13          SIZE 32M
14          AUTOEXTEND ON
15          NEXT 32M 
16          MAXSIZE UNLIMITED
17          EXTENT MANAGEMENT LOCAL;

    但!!!有时光坐您的表空间名和文书名不那么友好。这时候若老高兴的下shirt+delete永久删除(当然,这是自的惯,如果去回回收站直接回复就从不那么基本上细节了)。

    那要立即样子你会意识而再重复连接回Oracle的时候,恭喜你,遇到好东西,报错——ORA-01033:
ORACLE initialization or shutdown in progress

    如果起这个荒唐,如果你是大牛,你死淡定的解决掉了。可是!!!!你如跟自己同是一个恰巧入门的菜鸟,你晤面惴惴不安到怀疑人生,毕竟对于Oracle配置的不当,你只能说OMG。

    别慌,小志带你上车,亲测有效。

  2、解决办法

    a:首先尝试以Oracle的例用线程操作数据库

1 #此为cmd命令,使用管理员运行
2 sqlplus /nolog

    b:使用sysdba角色连接

1 SQL> user/ui as sysdba

    c:使用如下命令去你的表空间

1 SQL> alter database datafile 'E:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/TSTEST001.DBF' offline drop;
2 SQL> alter database open;
3 SQL> drop tablespace CTBASEDATA;

    d:使用上述命令重复使用直到提示而的不可开交数据文件不在

    e:在运此例程后记忆退出而的例程,不然你不怕gg

SQL > exit

   3、再次连后意识你能够接连数据库了,是匪是异常嗨森,别急,你查下而的本原的文件夹,虽然去了您的数据文件,但是你的临时文件还在。带有*temp.DBF的文书,这是您创造的临时表Oracle空间,记得还要删除掉,在命令行使用如下指令删除

SQL > alter database tempfile '你临时文件路径' drop including datafiles

  4、删除了最好还开下电脑,这样Oracle就足以高枕无忧用了,最后嘱咐大家,数据来高风险,建表需谨慎。

附:

创立用户指令

--创建用户
CREATE USER HOUSE IDENTIFIED BY  HOUSE_DATA
DEFAULT TABLESPACE HOUSE_DATA
TEMPORARY TABLESPACE HOUSE_TEMP;

改用户密码指令

alter user 用户名 identified by 新密码

 

相关文章