Oracle备份恢复之Flashback--闪回数据归档

huangshm 2019-03-12

概述

Oracle 引入闪回技术使得一些逻辑误操作不再需要利用归档日志和数据库备份进行时间点恢复,在前面介绍的诸多闪回技术中,除了Flashback Database依赖于闪回日志外,其它闪回技术都是依赖于Undo撤销数据,都与数据库初始化参数undo_retention密切相关,所以就存在一个限制就是undo中的信息不能被覆盖。

Oracle备份恢复之Flashback--闪回数据归档

Oracle11g中的闪回数据归档(Flashback Data Archive)与前面所说的闪回技术实现机制不同,它是通过将变化数据存储到创建的闪回归档区中,得以与undo区别开来。 同时Flashback Data Archive 并不是记录数据库的所有变化,而只是记录了指定表的数据变化,是Flashback database的补充。

Oracle备份恢复之Flashback--闪回数据归档


1.体系结构

Oracle备份恢复之Flashback--闪回数据归档


2.配置闪回数据归档

准备一个Oracle 11g数据库使用FBDA功能是相当简单的,只需要经过几个简单的步骤即可:

(1) 创建或指定一个或多个表空间用于FBDA保留历史数据

(2) 随意指派一个FBDA作为数据库的默认FBDA

(3) 指派一个用户账户作为FBDA管理员,授予它FLASHBACK ARCHIVE ADMINISTER系统权限

(4) 授予FBDA权限给适合的用户账号

(5) 授予FLASHBACK和SELECT权限给合适的FBDA表用户

(6) 为FBDA用户授予DBMS_FLASHBACK存储过程EXECUTE权限


3.访问历史记录数据的基本工作流:

创建闪回数据归档:

1. 创建闪回数据归档:

CREATE FLASHBACK ARCHIVE fla1 TABLESPACE tbs1 QUOTA 10GRETENTION 5 YEAR;

2. 对 FLA1 归档中的表启用历史记录跟踪:

ALTER TABLE inventory FLASHBACK ARCHIVE fla1;

3. 查看历史记录数据:

SELECT product_number, product_name, count FROM inventory AS OF TIMESTAMPTO_TIMESTAMP ('2019-01-01 00:00:00', 'YYYY-MM-DD HH24:MI:SS');

使用默认闪回归档:

1.创 建 默 认 闪 回 数 据 归 档

CREATE FLASHBACK ARCHIVE DEFAULT fla2TABLESPACE tbs1 QUOTA 10G RETENTION 2 YEAR;

2.对表启用历史记录跟踪:

ALTER TABLE stock _data FLASHBACK ARCHIVE;

注:因为使用了默认的闪回数据归档,所以不需要提供闪回数据归档名称。

3. 禁用历史记录跟踪:

ALTER TABLE stock _data NO FLASHBACK ARCHIVE;

4.维护闪回数据归档

1. 增加空间:

ALTER FLASHBACK ARCHIVE fla1 ADD TABLESPACE tbs3 QUOTA 5G;

2. 更改保留时间:

ALTER FLASHBACK ARCHIVE fla1 MODIFY RETENTION 2 YEAR;

3. 清除数据:

ALTER FLASHBACK ARCHIVE fla1 PURGE BEFORETIMESTAMP(SYSTIMESTAMP - INTERVAL '1' day);

4. 删除闪回数据归档:

DROP FLASHBACK ARCHIVE fla1;

篇幅有限,关于闪回归档就不做演示了,大家可以自己在虚拟机环境做相关测试。

后面会分享更多关于devops和DBA方面内容,感兴趣的朋友可以关注下!

Oracle备份恢复之Flashback--闪回数据归档

相关推荐