oracle 11g Flashback Data Archive(闪回数据归档)

标签: oracle 11g flashback | 发表时间:2013-06-28 21:51 | 作者:guoyJoe
出处:http://blog.csdn.net
Flashback Data Archive(闪回数据归档)
UNDO表空间记录的回滚信息虽然可以提供回闪查询,但时间久了,这些信息会被覆盖掉,其实只要事务一提交,他们就变成可覆盖的对象了,所以经常在做回闪查询时,我们会因为找不到undo block而收到1555错误,11G里面引入了Flashback Data Archive ,他用于存储数据的所有改变,时间由你自己设定,消耗的是更多的磁盘空间,现在来看下这个特性。


一、创建闪回数据归档
1、为了创建闪回数据归档,必须拥有DBA角色或拥有系统权限flashback archive administer。
sys@MYDB> select * from dba_sys_privs where privilege like '%FLASH%';


GRANTEE                        PRIVILEGE                                ADM
------------------------------ ---------------------------------------- ---
SYS                            FLASHBACK ANY TABLE                      NO
DBA                            FLASHBACK ANY TABLE                      YES
SYS                            FLASHBACK ARCHIVE ADMINISTER             NO
DBA                            FLASHBACK ARCHIVE ADMINISTER             YES




sys@MYDB> grant flashback archive administer to gyj;


Grant succeeded.


2、创建表空间
sys@MYDB> create tablespace flash_tbs1 datafile '/u01/app/oracle/oradata/mydb/flash_tbs1.dbf' size 20480M;


Tablespace created.


3、创建闪回归档


sys@MYDB> create flashback archive flash1 tablespace flash_tbs1  quota 1024M retention 5 year;


Flashback archive created.




二、更改闪回数据归档
sys@MYDB> alter flashback archive flash1 set default;


Flashback archive altered.


sys@MYDB> alter flashback archive flash1 add tablespace tp1; --添加表空间


Flashback archive altered.


sys@MYDB> alter flashback archive  flash1 remove tablespace tp1;--删除表空间


Flashback archive altered. 


sys@MYDB> alter flashback archive flash1 modify tablespace flash_tbs1 quota 2048M;--添加配额


Flashback archive altered.




sys@MYDB> alter flashback archive flash1 modify retention 3 year;


Flashback archive altered.




sys@MYDB> alter flashback archive flash1 purge all;  -- 清除所有


Flashback archive altered.


sys@MYDB> alter flashback archive flash1 purge before timestamp (systimestamp - interval '2' day);--清除2天前的


Flashback archive altered.


sys@MYDB> alter flashback archive flash1 purge before scn 123344;




Flashback archive altered.


三、启用和禁用闪回数据归档
1、在建表的同时就启用表的闪回日志
gyj@MYDB> create table t1(id int,name varchar2(10)) flashback archive flash1;


Table created.


2、也可以在建表后,再启用表的闪回日志
alter table t1 flashback archive;--为表启用闪回数据归档,没指定表示使用数据库默认的
alter table t1 flashback archive flash1; ;--为表启用闪回数据归档,指定在特定的闪回数据归档中存储表的变化


3、数据库将把T1表的数据归档到默认的闪回数据归档中
gyj@MYDB> select * from dba_flashback_archive_tables;


TABLE_NAME  OWNER_NAME  FLASHBACK_ARCHIVE_NAME  ARCHIVE_TABLE_NAME     STATUS
----------- -----------  ----------------------  ----------------  -------------
T1          GYJ          FLASH1                SYS_FBA_HIST_17877         ENABLED




4、在使用闪回数据归档前,必须设置默认闪回数据归档
gyj@MYDB> select flashback_archive_name,status from dba_flashback_archive;


FLASHBACK_ARCHIVE_NAME   STATUS                                                                           ------------------------------------
FLASH1                    DEFAULT                                                                          


5、禁用闪回数据归档
gyj@MYDB> alter table t1 no flashback archive;


Table altered.




四、闪回数据归档的限制
 在使用闪回归档的过程中有某些限制。对于已经启用闪回的表,不能使用DDL命令drop column(11r2可以drop column),但可以add column命令。删除属于一个启用了闪回数据归档的表列的唯一方法是首先关闭闪回归档功能。但是,这样会删除所有闪回归档数据。
1、ALTER TABLE:
Drops, renames, or modifies a column (11GR2是可以的)
Performs partition or subpartition operations
Converts a LONG column to a LOB column
Includes an UPGRADE TABLE clause, with or without an INCLUDING DATA clause
2、 DROP TABLE
3、TRUNCATE TABLE (11GR2是可以的)
4、RENAME TABLE (11GR2也是可以的)


gyj@MYDB> select * from v$version;


BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit Production


gyj@MYDB> alter table t1 drop column name;


Table altered.


gyj@MYDB> alter table t1 add(name varchar2(100));


Table altered.


gyj@MYDB> alter table t1 rename to t10;


Table altered.


gyj@MYDB> truncate table t10;


Table truncated.




gyj@MYDB> drop table t10;
drop table t10
           *
ERROR at line 1:
ORA-55610: Invalid DDL statement on history-tracked table




gyj@MYDB> alter table t10 no flashback archive;


Table altered.


gyj@MYDB> drop table t10;


Table dropped.


五、监控认回数据归档
1、查哪些表已经启用了闪回数据归档
gyj@MYDB> select * from dba_flashback_archive_tables;


TABLE_NAME  OWNER_NAME  FLASHBACK_ARCHIVE_NAME  ARCHIVE_TABLE_NAME     STATUS
----------- -----------  ----------------------  ----------------  -------------
T1          GYJ          FLASH1                SYS_FBA_HIST_17877         ENABLED


2、查数据库中所有的闪回数据归档
gyj@MYDB> select flashback_archive_name,retention_in_days from dba_flashback_archive;


FLASHBACK_ARCHIVE_NAME                             RETENTION_IN_DAYS
-------------------------------------------------- -----------------
FLASH1                                                          1095
 
3、查有关闪回数据归档所使用的表空间的信息
gyj@MYDB>  select flashback_archive_name,tablespace_name,quota_in_mb from dba_flashback_archive_ts;


FLASHBACK_ARCHIVE_NAME        TABLESPACE_NAME                QUOTA_IN_MB
---------------------------- ----------------------- -----------------
FLASH1                          FLASH_TBS1                     2048




六、使用闪回数据归档:例子
gyj@MYDB> create table test_gyj (id int,name varchar2(10));


Table created.


gyj@MYDB> alter table test_gyj flashback archive flash1;


Table altered.


gyj@MYDB> begin
  2   for i in 1 .. 100 loop
  3    insert into test_gyj values(i,'gyj'||i);
  4    commit;
  5   end loop;
  6   end;
  7   /


PL/SQL procedure successfully completed.




gyj@MYDB> select count(*) from test_gyj;


  COUNT(*)
----------
       100




gyj@MYDB> col FLASHBACK_ARCHIVE_NAME for a10
gyj@MYDB> col TABLE_NAME for a10
gyj@MYDB> col ARCHIVE_TABLE_NAME for a20
gyj@MYDB> col OWNER_NAME for a5
gyj@MYDB> select * from dba_flashback_archive_tables;


TABLE_NAME OWNER FLASHBACK_ ARCHIVE_TABLE_NAME   STATUS
---------- ----- ---------- -------------------- -------------
T1         GYJ   FLASH1     SYS_FBA_HIST_17890   ENABLED
T10        GYJ   FLASH1     SYS_FBA_HIST_17898   ENABLED
TEST_GYJ   GYJ   FLASH1     SYS_FBA_HIST_17908   ENABLED


gyj@MYDB> select count(*) from SYS_FBA_HIST_17908;


  COUNT(*)
----------
         0


gyj@MYDB> select current_scn from v$database;


CURRENT_SCN
-----------
    2353743


gyj@MYDB> delete from test_gyj;


100 rows deleted.


gyj@MYDB> commit;


Commit complete.


gyj@MYDB> select current_scn from v$database;


CURRENT_SCN
-----------
    2353790




gyj@MYDB>  select count(*) from test_gyj as of scn  2353743;




  COUNT(*)
----------
       100


gyj@MYDB> select count(*) from test_gyj as of scn  2353790;


  COUNT(*)
----------
         0


gyj@MYDB> select count(*) from SYS_FBA_HIST_17908;


  COUNT(*)
----------
         0


gyj@MYDB> select count(*) from SYS_FBA_HIST_17908;--刷新数据有缓慢,耐心等待!!!


  COUNT(*)
----------
       200
 


七、删除闪回归档数据
drop flashback archive flash1;




未完!!!继续更新中。。。。。。。。。。。。。。。。。。
作者:guoyJoe 发表于2013-6-28 21:51:55 原文链接
阅读:107 评论:0 查看评论

相关 [oracle 11g flashback] 推荐:

oracle 11g Flashback Data Archive(闪回数据归档)

- - CSDN博客数据库推荐文章
Flashback Data Archive(闪回数据归档). UNDO表空间记录的回滚信息虽然可以提供回闪查询,但时间久了,这些信息会被覆盖掉,其实只要事务一提交,他们就变成可覆盖的对象了,所以经常在做回闪查询时,我们会因为找不到undo block而收到1555错误,11G里面引入了Flashback Data Archive ,他用于存储数据的所有改变,时间由你自己设定,消耗的是更多的磁盘空间,现在来看下这个特性.

oracle 11g 之 result cache

- - CSDN博客数据库推荐文章
oracle 11g 之 result cache.   今天是2013-10-12,打算最近时间研究一下shared pool的相关原理以及awr报告分析. 今天学习一下在oracle 11g shared pool中新增的一个cache 那就是result cache.      现在开始研究一下result cache,对于oracle 11g 分为client result cache以及server result cache,前者在client进行内存的分配,后者对于数据库server进行内存分配,现在看一下server result cache(如下皆是server result cache内容).

Linux下安装Oracle 11g

- - Oracle - 数据库 - ITeye博客
1、 下载安装VMware Workstation v9.0.2 虚拟机软件,下载rhel-server-6.0-x86_64-dvd.iso安装Red Hat Enterprise Linux 6 64-bit操作系统到VMware中,安装时候添加Linux用户Oracle. 2、 在Vmware虚拟机中设置光驱属性为使用ISO映像文件linux.x64_11gR2_database.iso,并连接到虚拟机,拷贝光驱中的Oracle11G安装文件夹database到虚拟机的/u02/目录下.

[原]Oracle 11g 新特性 系列小结

- - David Dai -- Focus on Oracle
2012年12月15日,陆陆续续的花了几个星期的时间,把Oracle 11g的新特性熟悉了一遍,这里也只是部分特性,还有部分,如果以后有整理在补充进来. 这段时间Dave的状态并不太好,正所谓:如人饮水,冷暖自知,有些事只有经过了才能体会,不管怎么样,至少还有一件事是Dave 比较感兴趣,并且愿意为其付出很多的时间,那就是研究Oracle.

Oracle 11g AWR 系列五:如何生成 AWR 报告?

- - CSDN博客数据库推荐文章
1.生成单实例 AWR 报告:. 2.生成 Oracle RAC AWR 报告:. 3.生成 RAC 环境中特定数据库实例的 AWR 报告:. 4.生成 Oracle RAC 环境中多个数据库实例的 AWR 报告的方法:. 5.生成 SQL 语句的 AWR 报告:. 6.生成特定数据库实例上某个 SQL 语句的 AWR 报告:.

(总结)Oracle 11g常用管理命令(用户、表空间、权限)

- - 服务器运维与网站架构|Linux运维|X研究
PS:下面是Oracle 11g最常用的基本管理命令,包括创建用户、表空间,权限分配等. 以下命令本人都验证操作过,加上了本人的小结说明. 从root切换到oracle用户进入:. 进入sqlplus环境,nolog参数表示不登录:. 注:要把Linux下的Oracle配置成服务自启动,请看:. (原创)CentOS Linux下配置Oracle 11gR2为系统服务自动启动.

Oracle 11g系统自动收集统计信息的一些知识

- - CSDN博客数据库推荐文章
---11g的是 周一到周五 22:00-2:00 周六周日 6:00-4:00. WINDOW_NAME          REPEAT_INTERVAL                                              DURATION. CLIENT_NAME                                                      STATUS.

Oracle 收购 Ksplice

- feng823 - LinuxTOY
实现无需重启即可为 Linux 内核打安全补丁的 Ksplice 被 Oracle 收购. 在被收购前, Ksplice 为 Fedora, Ubuntu 免费提供该功能,对于 RHEL 和 CentOS 则需要订阅其产品. Oracle 表示将把 Ksplice 带来的零宕机安全更新功能添加到 Oracle 产品订阅服务中,同时停止对其他企业级 Linux 发行版的支持,将 Oracle Unbreakable Linux 打造成唯一具备零宕机安全更新功能的企业级 Linux 发行版.

Linux Ksplice,MySQL and Oracle

- Syn - DBA Notes
Oracle 在 7 月份收购了 Ksplice. 使用了 Ksplice 的 Linux 系统,为 Kernel 打补丁无需重启动,做系统维护的朋友应该明白这是一个杀手级特性. 现在该产品已经合并到 Oracle Linux 中. 目前已经有超过 700 家客户,超过 10 万套系统使用了 Ksplice (不知道国内是否已经有用户了.

oracle license计算

- Fenng - eagle's home
Oracle license的计算是基于CPU core的. 用core的数目乘以一个系数core factor就可以得到所需的oracle license的数目. 对于不同的CPU,core factor是不一样的,可以从oracle提供的这张列表中查到 Oracle Processor Core Factor Table.