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

发表于:2007-07-04来源:作者:点击数: 标签:
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
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

成功恢复,完成

原文转自:http://www.ltesting.net