把oracle数据库恢复到某个时间点或者某个scn

Posted 标配的小号

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了把oracle数据库恢复到某个时间点或者某个scn相关的知识,希望对你有一定的参考价值。

alter session set nls_date_format=‘yyyymmdd hh24:mi:ss‘;

select sysdate from dual;

conn dbauser/123456;      随便一个用户,然后删除其中的一张表用来做测试

drop table test;

 

rman target/

startup mount;

restore database;      还原数据文件

sql ‘alter session set nls_date_format="yyyymmdd hh24:mi:ss"‘;     因为在rman中执行,所以需要sql ‘’;

recover database until time ‘20110414 11:33:56‘;      恢复到这个时间的数据,执行之后需要重新生成重做日志文件

sql ‘alter database open resetlogs‘;

 

 

scn是指系统改变号,oracle数据库使用它来记录数据库的过去时间内的状态和轨迹

conn /as sysdba

select dbms_flashback.get_system_chage_number from dual;

select to_char(scn_to_timestamp(963959),‘YYYY-MM-DD HH24:MI:SS‘) from dual;       将scn转换为时间

select * from (select time_dp,scn from smon_scn_time order by time_dp desc) where rownum<10;  根据用户删除数据时间找出相应的scn号

rman target/

startup mount;

restore database;    还原数据文件

recover database until scn 963915;

sql ‘alter database open resetlogs‘;     重新生成重做日志文件

 

以上是关于把oracle数据库恢复到某个时间点或者某个scn的主要内容,如果未能解决你的问题,请参考以下文章

Oracle闪回

人工手动冷备不完全恢复介绍(purge表不完全恢复)

Oracle闪回技术[未完]

Oracle-闪回技术

12c RMAN 表级恢复

数据库恢复至某个时间点