基于SCN的不完全恢复

简介:         有几天没写了,呵呵!这几天比较忙,赶着做关于一个桌面搜索的软件。做了基于取消的不完全恢复和基于SCN的不完全恢复,一直没写成博客,现在可以补一下了。

        有几天没写了,呵呵!这几天比较忙,赶着做关于一个桌面搜索的软件。做了基于取消的不完全恢复和基于SCN的不完全恢复,一直没写成博客,现在可以补一下了。

先介绍一下:基于SCN 的不完全恢复是指将数据库恢复到某个特定的SCN 点的状态。当用户误执行了 drop table 或truncate table 之后,如果我们知道在这些操作点的SCN 的值,那么就可以使用基于SCN的不完全恢复方法了。

实验步骤如下:

1)先获取数据库当前的SCN值,模拟误删除实验表t1。

SQL> select current_scn from v$database;

CURRENT_SCN                                                                    
-----------                                                                    
    2598485                                                                    

SQL> drop table t1;

表已删除。

如上可知,误操作的SCN 的值大概为2598485 所以我们只要将数据库恢复到该SCN值即可。在实际的工作中DBA可以使用Logminer 确定误操作的SCN值。

2)关闭数据库,并加载。在恢复数据库时,要将数据库置于加载状态。

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

ORACLE 例程已经启动。

Total System Global Area  535662592 bytes                                      
Fixed Size                  1334380 bytes                                      
Variable Size             134218644 bytes                                      
Database Buffers          394264576 bytes                                      
Redo Buffers                5844992 bytes                                      
数据库装载完毕。

3)复制所有数据库文件的备份,为了将数据库恢复到过去的scn点,必须复制所有数据文件备份。
SQL> @f:\sql\recover.sql--------我写的一个关于恢复的脚本

注意,当复制数据文件备份时,必须确保备份文件的scn值小于要恢复到的scn值。所以使用以下查询,可以确定备份文件的SCN:

SQL> select file#,change# from v$recover_file;

     FILE#    CHANGE#                                                          
---------- ----------                                                          
         1    2585567                                                          
         2    2585567                                                          
         3    2585567                                                          
         4    2585567                                                          
         5    2585567                                                          
         6    2585567                                                          

已选择6行。

备份文件的SCN小于要恢复的SCN值。

4)执行不完全恢复。

SQL> recover database until change 2598485
完成介质恢复。

---注释:我做实验的时候,没有手工切换日志文件,所以没有显示:

指定日志: {=suggested | filename | AUTO | CANCEL} 这样的提示。


SQL> select * from t1;
select * from t1
              *
第 1 行出现错误:
ORA-01219: 数据库未打开: 仅允许在固定表/视图中查询

5)执行了不完全恢复之后,必须以resetlogs 方式打开数据库,并检查恢复结果。SQL> alter database open resetlogs;

数据库已更改。

SQL> select * from t1;

       NUM                                                                     
----------                                                                     
         1                                                                     
         2                                                                     
         3                                                                     
         4
       

由此可知恢复成功。      

6)当然执行了resetlogs之后,建议进行数据库的全备份。
SQL> archive log list
数据库日志模式            存档模式
自动存档             启用
存档终点            f:\app\yang\archive2
最早的联机日志序列     1
下一个存档日志序列   1
当前日志序列           1


SQL> alter database begin backup;

数据库已更改。

SQL> @f:\sql\hotbak.sql----关于备份的脚本
SQL> alter database end backup;

数据库已更改。

SQL> alter database backup controlfile
  2  to 'f:\lib\control.ctl' reuse;

数据库已更改。

SQL> alter system archive log current;------保持一致性。这一步,有时容易忽略

系统已更改

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
11月前
修复DataGuard备库中的datafile坏块一例
模拟备库块损坏 使用swingbench给主库施加一定的压力
|
Oracle 关系型数据库 数据库管理
|
存储 SQL Oracle
|
监控
rman 恢复部分归档日志
rac 数据库在恢复部分归档日志的时候,需要指定数据库的线程编号。
1861 0
|
SQL Oracle 关系型数据库