没有备份只有归档日志如何恢复数据文件

王朝other·作者佚名  2008-05-19
窄屏简体版  字體: |||超大  

系统环境:

1、操作系统:Windows 2000 Server,机器内存128M

2、数据库:

Oracle 8i R2 (8.1.6) for NT 企业版

3、安装路径:C:\ORACLE

模拟现象:

可通过重建数据文件来恢复,前提是归档日志文件保存完整

先将数据库设置为归档模式

SQL*Plus

conn system/manager

--创建实验表空间

create tablespace test datafile

'c:\test.ora' size 5M

AUTOEXTEND ON NEXT 1M MAXSIZE UNLIMITED

default storage (initial 128K next 1M pctincrease 0)

/

--创建实验用户

drop user test cascade;

create user test identified by test default tablespace test;

grant connect,resource to test;

conn test/test

create table a(a number);

insert into a values(1);

insert into a select * from a; --反复插入,达到100万条

commit;

--关闭数据库

SVRMGR connect internal

SVRMGR alter system switch logfile; --强制归档

SVRMGR alter system switch logfile;

SVRMGR alter system switch logfile;

SVRMGR shutdown

--操作系统下删除test.ora文件

--重新启动数据库

SVRMGR connect internal

SVRMGR startup

这时,可以mount上,但无法打开,因为数据文件test.ora不存在,

显示错误如下:

ORA-01157: ????/?????? 8 - ??? DBWR ????

ORA-01110: ???? 8: 'C:\TEST.ORA'

SVRMGR connect internal

SVRMGR startup mount

SVRMGR alter database create datafile 'c:\test.ora';

SVRMGR set autorecovery on

SVRMGR recover datafile 'c:\test.ora';

SVRMGR alter database open;

conn test/test

select count(*) from a; --数据又恢复到100万条

--删除实验表空间

conn system/manager

alter tablespace test offline;

drop tablespace test INCLUDING CONTENTS;

drop user test;

--如果是非归档模式,也可以运用以上方法,

--前提是:输入记录所占空间的大小不超过所有联机日志文件的大小

--即:用联机日志文件来恢复

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航