直接删除undo及temp表空间文件后的数据库恢复一例

前几天,某用户研发找到我,说他们的研发库坏了,问我能恢复不?我问他们做了什么操作,一个小男孩儿说,看到空间满了,清除了点儿数据,我说是不是连数据库的文件也清除了,他说没有,他清除的是ORACLE_HOME外的一个目录,和数据库没关系,见他这么说,我就没什么说的了,因为再说下去也是扯皮。登录系统查看,发现数据库可以mount,但在打开阶段会报错:

ORA-00603:ORACLE server session terminated by fatal error.

一时还真搞不清到底咋了,由spfile导出pfile,经查看undo表空间被删除了,只能采取了下面的步骤:

修改initsid.ora如下:

_corruption_rollback_segments=true;

undo_management='MANUAL'

undo_tablespace='SYSTEM'

用pfile启动,系统可以正常启动、打开,但很短时间内就会自动宕掉,因此,我必须尽快创建一个undo,为了尽快,我开始创建了一个只有50m的undo表空间undotbs2,然后,修改initsid.ora:

undo_management='AUTO'

undo_tablespace='UNDOTBS2'

再用pfile启动,系统可以正常启动、打开,但也是过了一段时间,就自动宕掉,后来,忽然看到一个报错,似乎说是和parallel servers有关,于是,修改initsid.ora:

parallel_max_servers=0

再用pfile启动、打开数据库后,这次数据库不自动宕掉了,接着,创建了一个大的undo表空间undotbs3,将系统undo表空间切换到这个大的新建的undo表空间undotbs3上,修改initsid.ora:

undo_tablespace='UNDOTBS3'

再以pfile启动、打开数据库,并drop掉那个小的undo表空间undotbs2,后来发现系统的temp表空间文件也被删除了,于是新建了temp表空间temp1,并把用户temp表空间切到新的temp表空间temp1上,然后,创建了spfile,并用spfile重启数据库,验证几天,一切正常。

供大家参考,如需转载,请注明出处。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lhdz_bj

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值