首页 > 代码库 > 归档模式下恢复没有备份的数据文件
归档模式下恢复没有备份的数据文件
测试环境
SQL> select * from v$version;
BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
PL/SQL Release 11.2.0.4.0 - Production
CORE 11.2.0.4.0 Production
TNS for Linux: Version 11.2.0.4.0 - Production
NLSRTL Version 11.2.0.4.0 - Production
创建表空间并设置用户
SQL> create tablespace t1 datafile ‘+data‘ size 20m;
Tablespace created.
SQL>
SQL> alter user test default tablespace t1;
User altered.
SQL> create table tt1 as select * from user_objects;
Table created.
SQL> select count(*) from tt1;
COUNT(*)
----------
6
SQL> select t.ts#, d.file#, d.name from v$tablespace t, v$datafile d where t.name=‘T1‘ and t.ts# = d.ts#;
TS# FILE# NAME
---------- ---------- --------------------------------------------------------------------------------
19 13 +DATA/key/datafile/t1.275.851106659
19 14 +DATA/key/datafile/t1.276.851107957
offline数据文件并在asm磁盘组删除相应数据文件
SQL> alter database datafile 13 offline;
Database altered.
ASMCMD> rm t1.275.851106659
ASMCMD> pwd
+data/key/datafile
ASMCMD>
测试
SQL> conn test/oracle;
Connected.
SQL> select * from tt1;
select * from tt1
*
ERROR at line 1:
ORA-00376: file 13 cannot be read at this time
ORA-01110: data file 13: ‘+DATA/key/datafile/t1.275.851109775‘
online数据文件报错
SQL> alter database datafile 13 online;
alter database datafile 13 online
*
ERROR at line 1:
ORA-01157: cannot identify/lock data file 13 - see DBWR trace file
ORA-01110: data file 13: ‘+DATA/key/datafile/t1.275.851106659‘
查看trace文件内容
key_dbw0_21473.trc
……
ORA-01157: cannot identify/lock data file 13 - see DBWR trace file
ORA-01110: data file 13: ‘+DATA/key/datafile/t1.275.851106659‘
ORA-17503: ksfdopn:2 Failed to open file +DATA/key/datafile/t1.275.851106659
ORA-15012: ASM file ‘+DATA/key/datafile/t1.275.851106659‘ does not exist
……
提示没有相应数据文件,可以通过alter database create datafile创建相应数据文件
SQL> alter database create datafile 13;
Database altered.
ASMCMD> ls
ELITEMASTER.274.849888559
MGMT_AD4J_TS.268.840720903
MGMT_ECM_DEPOT_TS.266.840720899
MGMT_TABLESPACE.267.840720901
SYSAUX.261.840712503
SYSTEM.260.840712485
T1.275.851109775
T1.276.851107957
TEST.270.842550281
UNDOTBS1.262.840712517
USERS.264.840712529
对比新增文件名T1.275.851109775 和原有数据文件+DATA/key/datafile/t1.275.851106659名称不一样
rename 数据文件并recover 然后online 打开查看
SQL> alter database rename file ‘+DATA/key/datafile/t1.275.851106659‘ to ‘+DATA/key/datafile/T1.275.851109775‘;
Database altered.
SQL> recover datafile 13;
Media recovery complete.
SQL> alter database datafile 13 online;
Database altered.
SQL> conn test/oracle
Connected.
SQL> select count(*) from tt1;
COUNT(*)
----------
6
恢复成功!
这个也同样适用于rac 恢复!