oracle12c因误删pdb数据⽂件导致整个数据库打不开的解
决⽅法
前⾔
最近因为⼀位同事误删了某个插件数据库(PDB)的数据⽂件,结果整个数据库,包括容器数据库(CDB),以及其他插件数据库都⽤不了了。⽆奈。。。通过尝试各种⽅法最终解决了,觉着有必要将解决的过程分享出来,⽅法⼤家参考学习,下⾯话不多说了,来⼀起看看详细的介绍吧。
⽅法如下:
1、⽤sys账号进⼊实例,可见容器数据库处于mounted状态;插在上⾯的所有PDB当然也都是mounted。
sqlplus sys/pwd@orcl12c as sysdba;
2、试图打开CDB,提⽰有数据库⽂件未能加载。
SQL> alter database open;
alter database open
*
第 1 ⾏出现错误:
ORA-01157: ⽆法标识/锁定数据⽂件 101 - 请参阅 DBWR 跟踪⽂件
ORA-01110: 数据⽂件 101:
'D:\APP\ADMINISTRATOR\ORADATA\ORCL12C\PDBDTJK\NMEMC.DBF'
⼜关闭⼜启动,来回折腾,都是如此:
SQL> shutdown immediate
ORA-01109: 数据库未打开
已经卸载数据库。
ORACLE 例程已经关闭。
SQL> startup
ORACLE 例程已经启动。
Total System Global Area 2147483648 bytes
Fixed Size    3834152 bytes
Variable Size    671092440 bytes
Database Buffers  1459617792 bytes
Redo Buffers    12939264 bytes
数据库装载完毕。
ORA-01157: ⽆法标识/锁定数据⽂件 101 - 请参阅 DBWR 跟踪⽂件
ORA-01110: 数据⽂件 101:
'D:\APP\ADMINISTRATOR\ORADATA\ORCL12C\PDBDTJK\NMEMC.DBF'
3、查阅⽹上资料,应该是将此遗失⽂件标为脱机、删除。但提⽰不到该⽂件!
SQL> alter database datafile 101 offline;
alter database datafile 101 offline
*
第 1 ⾏出现错误:
ORA-01516: 不存在的⽇志⽂件, 数据⽂件或临时⽂件 "101"
这就奇怪了,明明是你提⽰了该⽂件的,现在⼜说不知道这个⽂件。
4、估计是当前所在数据库是CDB,⽽这个⽂件属于PDB,所以应该切换到相关PDB,再进⾏⽂件脱机。
SQL> alter session set container=PDBDTJK;
会话已更改。
SQL> show pdbs;
CON_ID CON_NAME      OPEN MODE RESTRICTED
---------- ------------------------------ ---------- ----------
13 PDBDTJK      MOUNTED
5、脱机(offline,drop),成功!
SQL> alter database datafile 'D:\APP\ADMINISTRATOR\ORADATA\ORCL12C\PDBDTJK\NMEMC.DBF' offline;
alter database datafile 'D:\APP\ADMINISTRATOR\ORADATA\ORCL12C\PDBDTJK\NMEMC.DBF' offline
*
第 1 ⾏出现错误:
ORA-01145: 除⾮启⽤了介质恢复, 否则不允许⽴即脱机
SQL> alter database datafile 'D:\APP\ADMINISTRATOR\ORADATA\ORCL12C\PDBDTJK\NMEMC.DBF' offline drop;
数据库已更改。
6、切换回CDB,打开,成功!
SQL> alter session set container=CDB$ROOT;
会话已更改。
SQL> alter database open;
数据库已更改。
哎,我的天呐!呐啊~~~
7、总结
1)⼀个PDB损坏,导致整个CDB以及其他PDB都不能⽤,乃⾄于⽆法恢复?不应该啊,这可是oracle啊,不可能这么的还真是。听说oracle 12c r1版本就是,PDB宕机,CDB也会陪着⼀起宕;到r2就好⼀点,只宕PDB。
2)本次恢复,从CDB切换到PDB是关键。⽹上给出的答案,都是11g或以前的,⼀个实例对应⼀个数据
库,所以没有数据库切换的概念,⽂件说脱机就脱机了。
3)只要数据库实例能启动,不管CDB是否已打开,sys都能进去:
sqlplus sys/pwd@servername as sysdba;
⽽PDB则不⾏。在未打开的情况下,你⽤ conn user/pwd@servername 这种⽅式已经进不去了,但切换会话还可以:
SQL> alter session set container=PDBDTJK;
会话已更改。
这是孙悟空的⼀根救命毫⽑。为什么oracle网站进不去
4)以上问题的解决,现在看起来⼀步⼀步的,清晰明了,但这中间经过了多少煎熬和痛苦。昨天傍晚出现的问题,搞到21点,还没搞定。回家继续查资料到晚上快24点。早上七点醒来,才查了⼀下会话切换。早上是⼈最清醒的时候。
我都不清楚这个⽂件是怎么删除的。在继续使⽤的情况下,删除⽂件系统会提⽰被锁定,估计是停掉数
据库再删除,叉啊,这不是死吗。我都不敢想象,如果今天数据库没起来,会有⼀翻怎样的折腾。虽然是开发数据库,但好多项⽬在使⽤,各有各的PDB。
好了,以上就是这篇⽂章的全部内容了,希望本⽂的内容对⼤家的学习或者⼯作具有⼀定的参考学习价值,如果有疑问⼤家可以留⾔交流,谢谢⼤家对的⽀持。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。