设为首页 收藏本站
查看: 855|回复: 0

[经验分享] oracle误删除表空间后数据库如何修复的方法

[复制链接]
发表于 2016-8-22 08:51:51 | 显示全部楼层 |阅读模式
转载自:http://tiantianju.blog.sohu.com/64019322.html

oracle误删除表空间后数据库如何修复的方法  

1.创建一个新的表空间

  create tablespace rainbow

  datafile 'd:\oracle\oradata\oa_test5\rainbow01.dbf' size 10m;

2.在其中建表

  create table test

  (emp int)

  tablespace rainbow;

3.插入数据

  insert into test

  (emp) values(1000);

  commit;

4.备份控制文件

  alter database backup controlfile to 'd:\control.bak';

5.关闭数据库

  shutdown immeidate;

6.进行全备份

  备份所有的数据文件

7.打开数据库

  startup

8.删除表空间rainbow

  drop tablespace rainbow including contents; 16:46:03

9.为了验证我们再更新另外一个表空间里的test2表

  insert into test2 (emp) values(888);

  commit;

10.关闭数据库,并用6进行的全备份restore所有的数据文件(不完全恢复一定要全部的数据文件)

11.打开至mount;

  startup mount;

12.执行不完全恢复

  recover database until time'2007-03-23:16:46:00' using backup controlfile;

  (为什么要使用using backup controlfile 因为删除表空间后控制文件被修改了)

  SQL> recover database until time'2007-03-23:16:46:00' using backup controlfile;

  ORA-00279: 更改 471722 (在 03/23/2007 16:39:44 生成) 对于线程 1 是必需的

  ORA-00289: 建议: D:\ORACLE\ORADATA\OA_TEST5\ARCHIVE\ARC00001.001

  ORA-00280: 更改 471722 对于线程 1 是按序列 # 1 进行的



  指定日志: {<RET>=suggested | filename | AUTO | CANCEL}

  D:\ORACLE\ORADATA\OA_TEST5\redo03.log

  已应用的日志

  完成介质恢复

13.打开数据库

  alter database open resetlogs;

  数据库已更改

14.查询原来的数据

  select * from test;

  结果报错

  ERROR at line 1:

  ORA-00376: file 11 cannot be read at this time

  ORA-01111: name for data file 11 is unknown - rename to correct file

  ORA-01110: data file 11: '/opt/oracle/product/9.2.0/dbs/MISSING00011'



问题的原因:现在的控制文件中没有tablespace rainbow (前面已经将其删除)

  虽然我们用备份的控制文件对数据库进行了修复但是数据库打开时当前的控制

文件仍然是最新的控制文件。

  出现'/opt/oracle/product/9.2.0/dbs/MISSING00011' ,是因为数据库启动时

发现控制文件和system表空间中的dv信息不一致造成的

解决方法:重建控制文件

   用备份出来的控制文件'd:\control.bak'重命名即可,或使用由alter

database backup control file to trace 备份的进行重建。



15.重新开启数据库并查询数据

  SQL> select * from test;



          EMP

   ----------

         1000

  

  SQL> select * from test2;



  未选定行

说明数据库已经按我们的要求进行不完全恢复了

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-261109-1-1.html 上篇帖子: ORACLE 临时表空间使用率过高的原因及解决方案 下篇帖子: 如何在Oracle中写出性能优良的SQL语句(一)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表