AUL/MyDUL是和Oracle DUL具有同等功效的软件, 下面是如何使用这个工具进行恢复的详细步骤.
取得数据库的文件列表
如果你没有丢失迭制文件, 则可以从视图V$DATABASE查询取得. 否则你需要手工从磁盘中根据存留的文件, 来列出所有的文件.
SQL> col name format a40
SQL> select file#,rfile#,name from v$datafile;
FILE# RFILE# NAME
---------- ---------- ----------------------------------------
1 1 C:\ORACLE\ORADATA\SYSTEM01.DBF
2 2 C:\ORACLE\ORADATA\UNDOTBS01.DBF
3 3 C:\ORACLE\ORADATA\SYSAUX01.DBF
4 4 C:\ORACLE\ORADATA\TEST01.DBF
5 5 C:\ORACLE\ORADATA\AULTEST01.DBF
创建一个AUL/MyDUL使用的配置文件
配置文件是一个文本文件, 你可以用任何文本编辑器编辑. 文件应当包括三个列(文件号,相对文件号,文件名), 中间以空格分隔. 我们将上面的记录拷贝到文件db10g.cfg中就可以了. 如果数据文件的文件头块没有损坏, 文件号和相对文件号这两列的值是无关紧要的, 在打开时会自动读取文件头进行修正; 文件中不能包括空格, 否则请重命令文件去掉空格.
C:\MYDUL>type db10g.cfg
0 0 C:\ORACLE\ORADATA\SYSTEM01.DBF
0 0 C:\ORACLE\ORADATA\UNDOTBS01.DBF
0 0 C:\ORACLE\ORADATA\SYSAUX01.DBF
0 0 C:\ORACLE\ORADATA\TEST01.DBF
0 0 C:\ORACLE\ORADATA\AULTEST01.DBF
在AUL/MyDUL中打开配置文件
AUL/MyDUL从这个配置文件中读取数据文件列表, 成功打开后并读取文件头, 叫正配置文件中错误的"文件号"和"相对文件号". 在这里我们虽然有5个文件, 但由于我们没有使用, 免费的许可证只能让我们打开前面的2个文件, 并只能读取每个文件前面的256M.
Register Code: 55E2-4639-864D-F8C3
AUL : AnySQL UnLoader(MyDUL) for Oracle 8/8i/9i/10g, Trial Version 3.1.9
(C) Copyright Lou Fangxin 2005-2006 (AnySQL.net), all rights reserved.
AUL> open db10g.cfg
* ts# fno rfn ver bsize blocks filename
- ---- ---- ---- --- ----- ---------- -----------------------------------
Y 0 1 1 a2 8192 32768 C:\ORACLE\ORADATA\SYSTEM01.DBF
Y 1 2 2 a2 8192 8192 C:\ORACLE\ORADATA\UNDOTBS01.DBF
Y 2 3 3 a2 8192 8192 C:\ORACLE\ORADATA\SYSAUX01.DBF
Y 4 4 4 a2 8192 3072 C:\ORACLE\ORADATA\TEST01.DBF
生成AUL/MyDUL的数据字典
AUL/MyDUL可以根据"SYS.USER$","SYS.OBJ$","SYS.TAB$","SYS.COL$"四个系统表中的记录来生成所需的数据字典, 有数据字典的情况下恢复要容易得多.
AUL> UNLOAD TABLE USER$;
2006-08-04 09:39:00
2006-08-04 09:39:00
AUL> UNLOAD TABLE OBJ$;
2006-08-04 09:39:07
2006-08-04 09:39:08
AUL> UNLOAD TABLE TAB$;
2006-08-04 09:39:12
2006-08-04 09:39:13
AUL> UNLOAD TABLE COL$;
2006-08-04 09:39:17
2006-08-04 09:39:18
AUL> ! dir AUL*.TXT
Volume in drive C has no label.
Volume Serial Number is 5CF4-08FE
Directory of C:\MYDUL
2006-08-04 09:39 1,479,173 AULCOL.TXT
2006-08-04 09:39 272,935 AULOBJ.TXT
2006-08-04 09:39 36,112 AULTAB.TXT
2006-08-04 09:39 428 AULUSR.TXT
4 File(s) 1,788,648 bytes
使用LIST命令来生成恢复用的角本
命令"LIST TABLE 用户名 TO 角本文件名"可以用来生成恢复某个用户下所有表的AUL/MyDUL命令, 在这儿我省略了"TO 角本文件名", 将所有命令输出到屏幕上.
AUL> LIST TABLE MYDUL
UNLOAD TABLE MYDUL.T_PART TO T_PART.txt;
UNLOAD TABLE MYDUL.T_OBJECT TO T_OBJECT.txt;
UNLOAD TABLE MYDUL.T_LOB TO T_LOB.txt;
UNLOAD TABLE MYDUL.T_CLOB TO T_CLOB.txt;
UNLOAD TABLE MYDUL.T_PART PARTITION P2 TO T_PART_P2.txt;
UNLOAD TABLE MYDUL.T_PART PARTITION P1 TO T_PART_P1.txt;
运行恢复命令来恢复数据
我们来偿试恢复分区表"T_PART", 对于分区表一个分区会有一条命令. 在这儿省略了"TO 文件名", 因此所有记录直接显示在屏幕上.
AUL> UNLOAD TABLE MYDUL.T_PART PARTITION P2;
2006-08-04 09:40:42
Unload BJD=9928 FILE=4 BLOCK=19 CLUSTER=0 ...
150,1
2006-08-04 09:40:42
AUL> UNLOAD TABLE MYDUL.T_PART PARTITION P1;
2006-08-04 09:40:51
Unload BJD=9927 FILE=4 BLOCK=11 CLUSTER=0 ...
50,1
2006-08-04 09:40:51 下面是我用SQL*Plus连接进行查询的结果:
SQL> SELECT * FROM T_PART;
COL1 COL2
---------- ----------
50 1
150 1
SQL> SELECT * FROM T_PART PARTITION (P1);
COL1 COL2
---------- ----------
50 1
SQL> SELECT * FROM T_PART PARTITION (P2);
COL1 COL2
---------- ----------
150 1
恭喜我们恢复成功
接下来的事就是恭喜我们恢复成功.