利用数据文件恢复数据库

冷备份恢复

转载请注明出处:http://write.blog.csdn.net/postedit/41889405

现象:

利用数据文件异机数据重建;

只有数据文件的本机数据恢复。

实践环境:

Win server2003/xp+oracle11g32位;

 

 

小弟今日新装了v8软件,装完后,数据库突然不能使用,报ora-03113/ora-24324/ora-01041错误,由于原因太多、时间仓促,无法解决,就直接利用数据文件恢复了。

 

 

恢复原理:

由于数据文件在,所以只要重建spfile和control file即可。

 

恢复步骤:(这里为本机数据恢复步骤)

1.  打开oracle目录里面自带的工具创建新的实例;


打开后直接利用图文界面创建数据,下一步下一步完成就好;

 

2.备份新实例spfile和controlfile

在新数据库备份控制文件(这里操作时候没有截图):

Conn hgq  as sysdba;

Alter database backup controlfile to trace;

(这里第一备份控制文件,第二等下可以通过altert文件查看创建控制文件代码,稍后创建时候会用到);

备份pfile,createpfile from spfile;(这个先保存起来备份);

 

3.一定要关闭数据库后,删除新实例HGQ目录下的文件,及oradata下所有文件,然后复制PLMDEOMO实例oradata目录下所有数据文件(除控制文件外,要不然稍后创建控制文件会失败);

 

4.修改新实例hgq下面pfile,然后创建控制文件;

因为稍后要重建控制文件,所以,这里面要在pfile用#屏蔽掉原来的控制文件信息,同时原来的控制文件要删除掉。


然后nomount下创建控制文件;

Sqlplus/nolog;

Conn hgq as sysdba;

Startup nomount;

CREATE CONTROLFILE REUSE set DATABASE"HGQ"  RESETLOGS  ARCHIVELOG

   MAXLOGFILES 16

   MAXLOGMEMBERS 3

   MAXDATAFILES 100

   MAXINSTANCES 8

   MAXLOGHISTORY 454

DATAFILE

 'E:\oracle\oradata\HGQ\SYSTEM01.DBF',

 'E:\oracle\oradata\HGQ\UNDOTBS01.DBF',

 'E:\oracle\oradata\HGQ\SYSAUX01.DBF',

 'E:\oracle\oradata\HGQ\USERS01.DBF',

 'E:\oracle\oradata\HGQ\TEST01.DBF',

 'E:\oracle\oradata\HGQ\EXAMPLE01.DBF',

 'E:\oracle\oradata\HGQ\FJBB01.DBF',

 'E:\oracle\oradata\HGQ\HGQ.DBF',

 'E:\oracle\oradata\HGQ\HWFX1.DBF',

 'E:\oracle\oradata\HGQ\KFYY01.DBF'

LOGFILE

 GROUP 1 ('E:\oracle\oradata\HGQ\REDO01.LOG')  SIZE 10M,

 GROUP 2 ('E:\oracle\oradata\HGQ\REDO02.LOG')  SIZE 10M,

 GROUP 3 ('E:\oracle\oradata\HGQ\REDO03.LOG')  SIZE 10M

CHARACTER SET ZHS16GBK;

因为版本问题,这个代码可能会报错,这时候就可以查看alert文件中刚才备份的trace文件的位置,然后查看trace文件内容格式进行修改。

 

查看trace文件中代码格式:

  


5.控制文件已创建完毕,这时候需要修改pfile,然后启动数据库进行恢复;

修改pfile中刚才加#号的部分,去掉#号即可。

然后通过pfile启动数据库:


这时候会提示错误:ORA-01589: 要打开数据库则必须使用 RESETLOGS 或 NORESETLOGS 选项

然后执行alter  database open resetlogs;

但是这时候有可能会报错,系统文件出错:system表空间出错,

系统文件出错,看到“一致性”自然想到 _allow_resetlogs_corruption的隐含命令

 alter system set"_allow_resetlogs_corruption"=true scope=spfile;

执行上面的语句,然后再次执行语句alter  database open resetlogs;

接着

SQL> create spfile from pfile;

文件已创建。

 

SQL> select count(*) from dba_users;

 COUNT(*)

----------

       37

SQL> select count(*) from dba_userswhere username='HWFX';

 COUNT(*)

 

至此数据库恢复完成,打开数据库一看,数据都在。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值