Oracle 10 闪回功能实例讲解 联系客服

发布时间 : 星期日 文章Oracle 10 闪回功能实例讲解更新完毕开始阅读

Oracle 闪回特性(FLASHBACK DATABASE)

-- Oracle 闪回特性(FLASHBACK DATABASE) --=====================================

闪回技术通常用于快速简单恢复数据库中出现的认为误操作等逻辑错误,从闪回的方式可以分为基于数据库级别闪回、表级别闪回、事务

级别闪回,根据闪回对数据的影响程度又可以分为闪回恢复,闪回查询。闪回恢复将修改数据,闪回点之后的数据将全部丢失。而闪回查询则可

以查询数据被DML的不同版本,也可以在此基础之上确定是否进行恢复等。本文主要描述flashback database的使用。

一、flashback database特性

flashback data1base闪回到过去的某一时刻 闪回点之后的工作全部丢失

使用resetlogs创建新的场景并打开数据库(一旦resetlogs之后,将不能再flashback至

resetlogs之前的时间点)

常用的场景:truncate table、多表发生意外错误等 使用闪回日志来实现数据库闪回,闪回点之后的数据将丢失

二、flashback database的组成

闪回缓冲区:当启用flashback database,则sga中会开辟一块新区域作为闪回缓冲区,大小启用新的rvwr进程:rvwr进程将闪回缓冲区的内容写入到闪回日志中,注意闪回日志不同

上生成,是完整数据块映像的日志。联机日志则是变化的日志。闪回日志不能复用,

由系统分配

于联机重做日志,闪回日志在联机重做日志基础之 也不能归档。闪回日志使用循环写方式。

三、flashback database的配置

LOG_MODE OPEN_MODE FLASHBACK_ON ------------ ---------- ------------------

ARCHIVELOG READ WRITE NO --FLASHBACK_ON为NO,则表示闪回特性flashback database要求数据库必须处于归档模式,且闪回之后必须使用resetlogs打开a.查看数据库的归档模式及闪回是否启用

SQL> select log_mode,open_mode,flashback_on from v$database;

数据库

尚未启用

b.查看及设置闪回目录、闪回目录空间大小等

--下面查看恢复目录及恢复目路分配的大小

--可以使用alter system set db_recovery_file_dest 来设置新路径 --可以使用alter system set db_recovery_file_dest_size来设定新的大小

SQL> show parameter db_recovery

NAME TYPE VALUE

------------------------------------ ----------- -------------------------db_recovery_file_dest string /u01/app/oracle/flash_rec

_area

----- overy

db_recovery_file_dest_size big integer 2G

c.设置闪回保留目标生存期

SQL> show parameter db_flashback --缺省为分钟,即小时 NAME TYPE VALUE

------------------------------------ ----------- -------------------------db_flashback_retention_target integer 1440

SQL> alter system set db_flashback_retention_target=30; --设定保留时间为半

-----

小时

d.在mount状态下来启用flashback,如在open状态下则出现下列错误提示

SQL> alter database flashback on; alter database flashback on *

ERROR at line 1:

ORA-38759: Database must be mounted by only one instance and not open.

--一致性关闭数据库后,在mount状态下设置flashback SQL>startup mount exclusive;

SQL> select status from v$instance; STATUS ------------ MOUNTED

SQL> alter database flashback on; --开启闪回数据库功能 SQL> ho ps -ef | grep rvw --可以看到新增了后台进程rvwr oracle 3563 1 0 12:12 ? 00:00:00 ora_rvwr_orcl

--下面查看闪回区分配的大小为大约M,闪回分钟以内的数据则需要M左右的空间 --注意列oldest_flashback_time说明了允许返回的最早的时间点

SQL> select oldest_flashback_scn old_flhbck_scn,oldest_flashback_time old_ 2 retention_target rete_trgt,flashback_size/1024/1024 flhbck_siz, 3 estimated_flashback_size/1024/1024 est_flhbck_size 4 from v$flashback_database_log;

OLD_FLHBCK_SCN OLD_FLHBC RETE_TRGT FLHBCK_SIZ EST_FLHBCK_SIZE -------------- --------- ---------- ---------- ---------------

915137 24-OCT-10 30 7.8125 11.2519531

flhbck_tim,

SQL> select * from v$flashback_database_stat; --查看闪回

BEGIN_TIM END_TIME FLASHBACK_DATA DB_DATA REDO_DATA ESTIMATED_FLASHBA--------- --------- -------------- ---------- ---------- -----------------24-OCT-10 24-OCT-10 7905280 86802432 96329728

CK_SIZE ------- 0

SQL> select * from v$sgastat where name like 'flashback%'; --查看sga

中分配的闪回空间大小

POOL NAME BYTES ------------ -------------------------- ---------- shared pool flashback generation buff 3981204 shared pool flashback_marker_cache_si 9196

SQL> ho ls -hlt $ORACLE_BASE/flash_recovery_area/ORCL/flashback --查看生total 7.9M

-rw-r----- 1 oracle oinstall 7.9M Oct 24 12:37 o1_mf_6d7dkogw_.flb

成的闪回日志

四、使用flashback database闪回数据库 步骤(前提归档日志可用)

关闭数据库

启动数据库到mount状态(exclusive模式) 闪回至某个时间点,SCN或log sequence number 使用resetlogs打开数据库

可以接受一个时间标记或一个系统改变号实参 sqlplus几种常用的闪回数据库方法

FLASHBACK [STANDBY] DATABASE [] TO [BEFORE] SCN ] TO [BEFORE] TIMESTMP <

1.使用sqlplus实现闪回

change_number> --基于SCN闪回 system_timestamp_value>--基于时间戳闪回

FLASHBACK [STANDBY] DATABASE [] TO [BEFORE] RESTORE PO

INT --基于时点闪回

如下面的示例:

SQL> flashback database to timestamp('2010-10-24 13:04:30','yyyy-mm-ddSQL> flashback database to scn 918987;

SQL> flashback database ro restore point b1_load;

hh24:mi:ss');

a.基于时间戳闪回

SQL> select count(1) from usr1.tb1; --查询用户usr1下表tb1中的记录数 COUNT(1) ----------

404944

SQL> select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') tm from dual; --

获得系统当前的时间

TM

------------------- 2010-10-24 13:04:30

SQL> drop user usr1 cascade; --删除帐户usr1,同时帐户usr1下的所有

对象将被删除

SQL> conn scott/tiger; --使用scott 帐户登陆

SQL> create table tb_emp as select * from emp; --新创建表tb_emp SQL> shutdown immediate; --关系系统 SQL> startup mount ; --重新到mount状态 SQL> flashback database to timestamp --实施闪回

2 to_timestamp('2010-10-24 13:04:30','yyyy-mm-dd hh24:mi:ss') ;

SQL> alter database open resetlogs;

SQL> select count(1) from usr1.tb1; --帐户usr1及其对象tb1被成功闪

COUNT(1) ----------