欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

Oracle 数据文件误删除的不完全恢复

程序员文章站 2024-01-25 19:16:22
...

应用环境:我的一个表被人不小心误删除了,这时候,我不可以把整个库都恢复回去,那样太麻烦了。所以现在我就从新到一个新库,只将这一个数据文件拷贝过来恢复。

应用环境: 我的一个表被人不小心误删除了,这时候,我不可以把整个库都恢复回去,那样太麻烦了。

所以现在我就从新到一个新库,,只将这一个数据文件拷贝过来恢复。


那我们Oracle在恢复文件的时候是不可以只恢复一部分数据文件的,因为oracle 要保证数据文件块头信息一致,所以如果我们要恢复部分文件的话,就得采取以下这种方法:

$ORACLE_SID=rt sqlplus / as sysdba >startup nomount pfile='/tmp/pfile.ora'

接着控制文件怎么办呢,

2)当然我们可以将之前备份的数据文件直接恢复到我们配置的参数文件中控制文件的路径。

恢复控制文件:

rman target > restore controlfile to '/u01/app/oracle/oradata/test/rt_con01.ctl' from '/tmp/FULL_04pe7jue_1_1.bak';


那现在可以mount了。

现在是不可以open的,如果你现在open,他就会把原来的logfile 覆盖,那肯定原来的那个库会出问题。

3)我们这里要做的就是先恢复数据文件:

在rman中用到一个newname,首先确定原来的system,undo,还有要恢复的表空间文件号。

run { allocate channel di type disk; set newname for datafile 1 to '/tmp/disk1/system01.dbf'; set newname for datafile 3 to '/tmp/disk1/undotbs01.dbf'; set newname for datafile 9 to '/tmp/disk1/test_01.dbf'; restore datafile 1,3,9; }

当然你执行上面会报错,因为我们是新创建的控制文件,所以要注册一下:

rman >catalog start with '/tmp/FULL_04pe7jue_1_1.bak'

4) 然后在主库更改redo日志:

select * from v$log; GROUP# THREAD# SEQUENCE# BYTES BLOCKSIZE MEMBERS ARC STATUS FIRST_CHANGE# FIRST_TIME NEXT_CHANGE# ---------- ---------- ---------- ---------- ---------- ---------- --- ---------------- ------------- ------------------- ------------ NEXT_TIME ------------------- 1 1 75 52428800 512 2 YES INACTIVE 4215102 2014-07-26:22:18:25 4215195 2014-07-26:22:19:55 2 1 74 52428800 512 2 YES INACTIVE 4211699 2014-07-26:20:55:55 4215102 2014-07-26:22:18:25 3 1 76 52428800 512 2 NO CURRENT 4215195 2014-07-26:22:19:55 2.8147E+14

当前正在用的是group 3,那我们可以删除group1;

SYS@_connect_identifier>alter database drop logfile group 1; 数据库已更改。 SYS@_connect_identifier>alter database add logfile group 1('/u01/app/oracle/oradata/test/mredo01.log') size 60m reuse; 数据库已更改。

跟着删除group 2 :

SYS@_connect_identifier > alter database drop logfile group 2; 数据库已更改。 SYS@_connect_identifier > alter database add logfile group 2('/u01/app/oracle/oradata/test/mredo02.log') size 60m reuse; 数据库已更改。

那3就要跟着切换日志,做完全检查点了:

SYS@_connect_identifier>select * from v$log; GROUP# THREAD# SEQUENCE# BYTES BLOCKSIZE MEMBERS ARC STATUS FIRST_CHANGE# FIRST_TIME NEXT_CHANGE# ---------- ---------- ---------- ---------- ---------- ---------- --- ---------------- ------------- ------------------- ------------ NEXT_TIME ------------------- 1 1 0 62914560 512 1 YES UNUSED 0 0 2 1 0 62914560 512 1 YES UNUSED 0 0 3 1 76 52428800 512 2 NO CURRENT 4215195 2014-07-26:22:19:55 2.8147E+14 SYS@_connect_identifier>alter system switch logfile; 系统已更改。 SYS@_connect_identifier>alter system checkpoint; 系统已更改。 SYS@_connect_identifier>alter database drop logfile group 3; 数据库已更改。 SYS@_connect_identifier>alter database add logfile group 3('/u01/app/oracle/oradata/test/mredo03.log')size 60m reuse; 数据库已更改。

将备库中不用数据文件更改掉

alter database datafile 2 offline drop;

alter database datafile 4 offline drop;

alter database datafile 5 offline drop;

alter database datafile 6 offline drop;

alter database datafile 8 offline drop;

alter database datafile 10 offline drop;

6)备库更改数据文件路径和归档日志文件路径:

SYS@_connect_identifier>alter database rename file '/u01/app/oracle/oradata/test/system01.dbf' to '/tmp/disk1/system01.dbf' 2 ; 数据库已更改。 SYS@_connect_identifier>alter database rename file '/u01/app/oracle/oradata/test/undotbs01.dbf' to '/tmp/disk1/undotbs01.dbf'; 数据库已更改。 SYS@_connect_identifier>alter database rename file '/u01/app/oracle/oradata/test/test_01' to '/tmp/disk1/test_01.dbf'; 数据库已更改。 SYS@_connect_identifier>set LOGSOURCE '/tmp/disk1/arch';
相关标签: oracle 数据恢复