os:winxp
oracle:9.2.0.1.0
sid:xianhe

我的备份和恢复实验(归档模式下用户管理的不完全恢复,基于时间点的)

os:winxp
oracle:9.2.0.1.0
sid:xianhe

一:准备工作

把数据库改为归档模式

SQL> startup mount
ORACLE 例程已启动。

Total System Global Area 126950220 bytes
Fixed Size 453452 bytes
Variable Size 109051904 bytes
Database Buffers 16777216 bytes
Redo Buffers 667648 bytes
数据库装载完毕。
SQL> alter database archivelog;

数据库已更改。

SQL> alter database open;

数据库已更改。

SQL>

配置成自动归档
SQL> alter system set log_archive_start = true scope=spfile;

系统已更改。

确定数据库在归档模式下并是自动存档的
SQL> archive log list
数据库日志模式 存档模式
自动存档 启用
存档终点 D:\oracle\ora92\RDBMS
最早的概要日志序列 2
下一个存档日志序列 4
当前日志序列 4
SQL>

干净的关闭数据库,做一个完全的冷备份。

二:开始实验

数据库在很多情况下要进行不完全的恢复,如用户误删除重要的表等。

1:time-based recovery

SQL> select * from salgrade;

GRADE LOSAL HISAL
---------- ---------- ----------
1 700 1200
2 1201 1400
3 1401 2000
4 2001 3000
5 3001 9999

把scott用户的salgrade表删除
SQL> drop table scott.salgrade;

表已丢弃。

时间是
SQL> select to_char(sysdate, 'yyyy-mm-dd:hh24:mm:ss') from dual;

TO_CHAR(SYSDATE,'YY
-------------------
2005-03-18:20:03:51

关闭数据库

SQL> shutdown immediate;
数据库已关闭。
已卸载数据库。
ORACLE 例程已关闭。

然后做一次完全数据库冷备份,保留现场,万一恢复不成功能够恢复现场。以下恢复不是用的这个备份。

把原先备份的数据文档(不包括控制文档和日志文档)还原回去。


数据库启动到mount状态
SQL> startup mount
ORACLE 例程已启动。

Total System Global Area 126950220 bytes
Fixed Size 453452 bytes
Variable Size 109051904 bytes
Database Buffers 16777216 bytes
Redo Buffers 667648 bytes
数据库装载完毕。

SQL> recover database until time '2005-03-18:20:03:51';
完成介质恢复。
SQL> alter database resetlogs;
alter database resetlogs
*
ERROR 位于第 1 行:
ORA-02231: 缺少或无效的 ALTER DATABASE 选项


SQL> alter database open resetlogs;

数据库已更改。

SQL> select * from scott.salgrade;

GRADE LOSAL HISAL
---------- ---------- ----------
1 700 1200
2 1201 1400
3 1401 2000
4 2001 3000
5 3001 9999

成功恢复,完成