欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-06-29 14:38:24
flashback data archive(闪回日志归档)其实理解为长时间的保存undo数据,对于某些重要的表可以自定义它的历史记录保存期限,它的的种种行为与undo表空...

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