Oracle 11g 新特性 Flashback Data Archive 使用实例


Flashback Data Archive(闪回日志归档)其实理解为长时间的保存undo数据,对于某些重要的表可以自定义它的历史记录保存期限,它的的种种行为与undo表空间十分相似,使用的时候也是完全透明的,用户不知道它的查询一致性视图数据是来自undo还是Flashback Data Archive,现来分析它与undo的几点不同:

1.Flashback Data Archive仅记录UPDATE和DELETE语句,不记录INSERT语句。

2.Flashback Data Archive中的行数据库可以保存非常长的时间,甚至是几十年,相比之下的undo数据中的对象通常只有几个小时或者几天的保留期限。

3.Flashback Data Archive和undo的本质功能是不同的,它只关注表行的历史改动,而非undo来实现数据库整体事务的读一致性,已经回滚操作等。

那么Flashback Data Archive是怎么实现的呢,设想既然是保存表中的行记录,应该是需要单独的存储区域来记载行记录的,为这个区域指定保留期限,这样其中的数据就会长久的保留下去,然后再在想要记录的表上添加跟踪标记,这样就可以实现行记录的归档保存了,实际上这便是Oracle的实现原理,这里的存储区域就是Flashback Data Archive,在使用过程中使用create flashback archive命令创建。

一、创建归档

Oracle建议使用单独的表空间来存储Flashback Data Archive,当然也可以在一个已经存在的表空间上创建一个或多个Flashback Data Archive,

–创建前需要保证执行用户具有FLASHBACK_ARCHIVE_ADMINISTRER权限,该权限包括创建和修改flashback archive,启用表跟踪,管理归档中的表空间等)

复制代码 代码如下:

SQL> create tablespace fbda1
2  datafile '/u01/app/oracle/oradata/prod/fbda01.dbf'
3  size 5g;

Tablespace created.

接下来开始创建Flashback Data Archive:

复制代码 代码如下:

SQL> create flashback archive fb_01
2  tablespace fbda1 quota 300m
3  retention 10 year;

Flashback archive created.

上面的命令创建了一个保存十年的Flashback Data Archive,它可以使用fbda1表空间中300m的空间(有点小了。。。),根据需要我们可以再创建一个默认的归档,使用default关键字,如

复制代码 代码如下:

SQL> create flashback archive default fb_dflt
2  tablespace fbda1
3  retention 1 year
4  /

Flashback archive created.

查询DBA_FLASHBACK_ARCHIVE视图获取归档的信息,包括保留期限,状态等

复制代码 代码如下:

SQL> select OWNER_NAME,FLASHBACK_ARCHIVE_NAME,
2  FLASHBACK_ARCHIVE#,RETENTION_IN_DAYS,STATUS
3  from dba_flashback_archive;
 
OWNER_NAME FLASHBACK_ARCHIVE_NAME FLASHBACK_ARCHIVE# RETENTION_IN_DAYS STATUS
---------- ---------------------- ------------------ ----------------- -------
SYS        FB_01                                   1              3650
SYS        FB_DFLT                                 2               365 DEFAULT

查询FLASHBACK_ARCHIVE_TS视图获取表空间和归档的对应关系

复制代码 代码如下:

SQL> select * from dba_flashback_archive_ts;

FLASHBACK_ARCHIVE_NAME    FLASHBACK_ARCHIVE# TABLESPACE_NAME      QUOTA_IN_MB
------------------------- ------------------ -------------------- ------------
FB_01                                      1 FBDA1                300
FB_DFLT                                    2 FBDA1

二、跟踪表到指定的Flashback Data Archive中

将scott用户的emp表分配到fb_01归档下:

复制代码 代码如下:

SQL> alter table scott.emp flashback archive fb_01;

Table altered.

查询DBA_FLASHBACK_ARCHIVE_TABLES视图可以获得已经归档的表:

复制代码 代码如下:

SQL> select * from dba_flashback_archive_tables;

TABLE_NAME OWNER_NAME FLASHBACK_ARCHIVE_NA ARCHIVE_TABLE_NAME   STATUS
---------- ---------- -------------------- -------------------- --------
EMP        SCOTT      FB_01                SYS_FBA_HIST_73181   ENABLED

三、查询使用Flashback Data Archive

这里的使用和undo完全没有异样了,在查询中指定as of就可以了,这里演示查询3年前的emp表数据:

复制代码 代码如下:

SQL> select empno,ename,hiredate
 2 from scott.emp
 3 as of timestamp (systimestamp - interval '3' year)
 4 where empno=7934;

EMPNO ENAME      HIREDATE
 ---------- ---------- ---------
 7934 MILLER     23-JAN-82



相关阅读:
LINQ字符串向datetime 转换时失败的处理方法
Java IO流 文件传输基础
PHP采用XML-RPC构造Web Service实例教程
在CentOS服务器上安装配置LEMP的详细教程
轻松学习C#的基础入门
Yii2中关联查询简单用法示例
遍历DOM对象内的元素属性示例代码
将Access数据库中数据导入到SQL Server中的详细方法实例
Android SlidingDrawer 抽屉效果的实现
php中JSON的使用方法
HTML5全屏(Fullscreen)API详细介绍
Javascript中匿名函数的多种调用方式总结
详解Java中用于查找对象哈希码值的hashCode()函数
Gridview使用CheckBox全选与单选采用js实现同时高亮显示选择行
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 SQL jQuery C# C++ java Android IOS oracle MongoDB SQLite wamp 交通频道 作文范文 那种所谓的小感情 世界上最完美的“工具” 牵手2016食品安全伴我行活动实践个人总结 经典爱情短语短句大全 “红梅赞”,赞一赞身边的“吴老师”650字 青春的城门作文1200字 笑到抽筋的笑话 孤寂迷恋 2016年新区农、林工作总结 教学型高校大学生科研训练培养模式研究 遇见你是我最美丽的意外 IBM的员工培训 同学们 新婚快乐 一年级数学教学工作计划 你的时间,是你的无价之宝 高二数学备课组工作计划(2005—2010学年第一学期) 爷爷的烧红苕作文900字 《坚不可摧》经典台词 唠叨老太婆作文400字 关于自信的初中作文_我,不平凡 有关诚信的古诗词 感恩伴我前行 粘人的冰豆腐作文800字 代别离·秋窗风雨夕 感想——读《小王子II》有感350字 初中生自我评价400字(5篇) 高中高三作文1000字:丙戌变法 猪八戒办学作文700字 埋藏在心中的感动 四年级下册数学暑假作业答案 大学毕业生实习周记汇编 留给孩子的记忆之“锅巴粥” 我的网络文学创作之路 一村一品包扶工作总结 2016五一劳动节致家长的一封信 关于贴对联的作文200字 电冰箱自述作文350字 校园生活文章:美好的校园时光 男同学们,你们醒一醒!作文500字 我想起曾经一个网友 堕落 幸福 麻木 转身 已全部离开我 不要再让我抬不起头来 《性格分析与调适》教案(第一课时)(会员上传) 描写城市夜晚的句子 在记忆中缓缓流淌 2016品牌汽车巡展实施方案 学会调节心态,才会轻松洒脱 论旅游投诉处理系统的建立 离别后,走过某处不知名的忧伤作文500字 坏学生 小学六年级作文800字:我的“泡泡”,还在膨胀

Copyright © 2016 phpStudy |