如何解决当oracle 12c误删pdb数据文件导致整个数据库打不开的问题

来源:爱站网时间:2021-05-14编辑:网友分享
如果遭遇oracle 12c因误删pdb数据文件直接导致整个数据都无法打开的情况要怎么去处理,下文会用示例代码来详细介绍,需要的朋友随着爱站技术频道小编来看看这篇如何解决当oracle 12c误删pdb数据文件导致整个数据库打不开的问题。

方法如下:

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;

会话已更改。

这是孙悟空的一根救命毫毛。

4)以上问题的解决,现在看起来一步一步的,清晰明了。

上文爱站技术频道小编带来的关于如何解决当oracle 12c误删pdb数据文件导致整个数据库打不开的问题的内容已介绍完,可以继续关注爱站技术频道小编来了解更多与oracle数据库知识。

上一篇:oracle普通表如何转化成分区表的教程

下一篇:怎么恢复数据库ORA-01196故障时归档日志丢失问题

您可能感兴趣的文章

相关阅读

热门软件源码

最新软件源码下载