Oracle 闪回技术

---闪回技术FLASHBACK

    闪回的文件存放在 闪回(快速)恢复区。通过  db_recovery_file_dest 初始化参数指定其位置。 db_recovery_file_dest_size  参数
 设置其大小。
     alter system  set db_recovery_file_dest='path';
     alter system set db_recovery_file_dest_size=3G scope=BOTH;
    停用闪回恢复区
 alter system set  db_recovery_file_dest='';
    与闪回恢复区相关的视图有:
 dba_outstanding_alerts     相关警告信息
 v$recovery_file_dest     可以监控恢复区的使用空间情况
 v$flash_recovery_area_usage 与文件类型及空间有关的视图
 v$controlfile\ v$logfile \ v$archived_log \v$datafile_copy 中的列 is_recovery_dest_file 指明相关的文件是否在恢复区。

    闪回技术组要是7个功能的总称:1、闪回查询(闪回时间点查询,闪回版本查询)     2、闪回数据归档
                                 3、闪回事务查询、         4、闪回事务、         5、闪回表
                                 6、闪回删表                                7、闪回数据库
                                                           
    闪回技术是基于撤销空间、撤销数据块的。 初始化参数  undo_retention 的值 表示修改所产生的撤销数据应该在发起修改
        的事提交之后再保留的时间长度,单位是秒。默认值是900秒 即 15 分钟。默认的数据库是不尊重900s以上的任何设置。
           即默认 是 NOGARANTEE (select retention from dba_tablespaces where tablespace_name='UNDOTBS1');
           可以修改为 retention (alter  tablespace undotbs1 retention guarantee);
           修改保留时长: alter system set undo_retention =300;
       
     撤销数据的保留策略 取决于 :初始化参数 undo_retention 、undo表空间的数据文件是否启用自动增长
                                 undo 表空间是否绝对尊重undo_retention的值、数据库中的事务量。
    闪回查询:  只是提供查看功能呢
 语法:
  select column1...from table_name as of [SCN|TIMESTAMP] where...
            闪回时间点查询:查询过去的某个时间点的数据.用法是在 表名后 加 as of
            select * from test_user.tt as  of  timestamp (systimestamp-interval '5' minute) where id=12; ---查询5分钟前的数据
            select * from test_user.tt as of timestamp to_timestamp('2010-10-01 01:03:19','yyyy-mm-dd hh24:mi:ss');--查询某个时间点时所有数据
          ---查询10分钟前 a 表 与 2分钟前 b 表的关联数据集
            select * from test_user.tt as of timestamp (systimestamp-interval '10'minute)a,
                                test_user.tb as of timestamp (systimestamp- interval '2' minute) b where a.id=b.ref_id;
                               
            ---将某字段的值修改为10分钟前的值
            update test_user.tt set value=(select value from test_user.tt as of timestamp(systimestamp- interval '10' minute) where id=123)
                where id=123;
            也可用通过调用pl/sql 包 dbms_flashback.enable_at_time 和 dbms_flashback.enable_at_scn  存储过程锁定一个会话级的
            闪回时间目标,即进入闪回模式,这样就可以省略 “  as of ”直到调用 dbms_flashback.disable 存储过程关闭闪回模式。
            sys 用户不能调用这两个存储过程。同时 sysdate \systimestamp 不能定格。
            ---将会话锁定在15分钟前
             exec dbms_flashback.enable_at_time (systimestamp - interval '15' minute);
             select * from test_user.tt;
             exec dbms_flashback.disable;
            
             闪回版本查询:
   语法:
   select column1.... from table_name versions between [SCN|TIMESTAMP]
    [<expr> |MAXVALUE] AND <EXPR> | MINVALUE] | AS OF [SCN|TIMESTAMP]<expr>
    as of:指恢复单个版本。

   该查询方式 贯穿一定长度的时间窗口,通过只能使用一条查询命令就能返回该时间窗口的不同时间
                                        点上的数据。语法为 表名之后加  versions between 子句。
                      ----指定时间窗口是10分钟前到当前时间的满足条件的数据。
                     select * from test_user.tt versions between timestamp(systimestamp - interval '10' minute) and maxvalue
                                            where department_id=123456;
                                           
                       -----闪回版本特有的伪字段可以查看清事务的先后顺序
                       select versions_xid,versions_startscn,versions_endscn,
                                versions_starttime,versions_endtime,* from test_user.tt  versions between
                            timestamp(systimestamp-interval '10'minute) and maxvalue where department_id=123456
                            order by 2 nulls first;
                            versions_xid:事务号                versions_startscn:事务开始时的SCN
                            versions_endscn:修改该行的下一个事务开始时的SCN。
                           
       闪回数据归档(flashback data archive): 延伸了闪回查询的时间窗口
            闪回数据归档的工作原理是:将只能保存在UNDO表空间的撤销数据额外的以一种历史的形式保存在指定的普通表空间
            中。并且不像初始化参数 undo_retention 参数那样影响整个数据库,它可以只为特定的表服务。在指定的表空间中创建
            一个能够为保存的“旧”数据的数据归档,创建数据归档必须有 flashback archive administrator 系统权限。
            create flashback archive arc_name tablespace 指定的表空间 retention  30 day;
            create flashback archive default arc_name tablespace 指定的表空间 retention 1 year;----创建默认闪回数据归档
     给数据归档区 arc_name 增加一个表空间
  alter flashback rachive arc_name add tablespace table_space_name
     删除数据归档区 arc_name 的表空间 table_space_name ,此删除仅表示从数据归档区删除,并不删除该表空间
  alter flashback archive arc_name remove talespace table_space_name
     修改归档区的磁盘限额
  alter flashback archive arc_name modify tableapce tble_space_name
     修改归档区的保留策略
  alter flashback archive arc_name modify retention 1 month;
           
            在特定的表上 加 flashback archive 子句 启用其上的闪回数据归档功能。
             alter table test_user.tt flashback archive arc_name;
             启用数据归档需有 sysdba权限。如果是普通用户,则需被授权 grant flashback archive on arc_name to 普通用
             这里的arc_name 数据归档名 如果有默认闪回数据归档,则可以省略不写。
            
             在创建时,可以指定所使用的闪回数据归档
             create table test_user.tb(id integer,name varchar2(32)) flashback  archive arc_name;
             关闭在表上的闪回数据归档
             alter table test_user.tb no flashback archive;
             限制闪回归档使用表空间配额
             create flashback archive arc_name tablespace 指定表空间 quota 1G  retention 60 day;
             删除闪回数据归档中的历史数据(手工)
             alter flashback archive arc_name purge before timestamp(systimestamp - interval  '1' month);
             清除全部
             alter flashback archive arc_name purge all;
             常用闪回数据归档 表查询
             dba_flashback_archive \ dba_flashback_archive_ts \dba_flashback_archive_tables
            
            
    闪回事务查询:提供了撤销SQL,还需自己手动执行。
        特点:需要撤销数据,还需要启用最小补充日志;返回的结果是能够将当前数据修改为以前的样子的撤销SQL语句(undo sql),
                    而非 “旧”值。集中地在名为  flashback_transaction_query 表上查询,而非在各个表上通过 as of 或 versions between 子句查询。
                    步骤:
                        1、select versions_xid,versions_startscn,versions_endscn,col1 from test_user.tt versions between timestamp minvalue and maxvalue
                                where departid=123 order by 2 nulls first; ---通过闪回版本获得事务XID
                        2、select undo_sql from flashback_transaction_query where xid='查询到的事务的XID';
                        3、根据事务的XID 查询得出的ROWID的值,到表中 查询并分析事务的先后顺序并执行还原即可(谨慎使用)
                            SELECT * FROM TEST_USER.TT WHERE ROWID='值';
                           
     闪回事务(flashback transaction):
            闪回事务又称 撤销事务,能够撤销一个或多个事务的修改,其功能是由一个名为 dbms_flashback.transaction_backout 的存储过程
                    来实现的。该存储过程的工作原理是:自动分析重做日志,挖掘出变更前的值用以构建撤销SQL,然后执行撤销SQL最后达到
                    撤销事务的目的,需要启用主键补充日志,为了能够跟踪外键依赖还需启用外键补充日志。
                    dbms_flashback.transaction_backout 的步骤是:
                    1、将需撤销的事务的事务号或事务名载入对应的 VARRAY 集合变量中;
                    2、以 NOCASCADE 方式调用 transaction_backout,再从 另外3种 (cascade、nocascade_force、nonconfilict_only)方式中选一种
                        调用 transaction_backout.
                    3、查看闪回事务操作的报告
                    4、最后决定提交或回滚。
                   
       闪回表(flashback table)    
            以表为单位将数据恢复为 以前的样子。闪回表同样是利用 undo 表空间的撤销数据,故闪回表能闪回到多久前同样受闪回查询
            4个因素影响。闪回数据归档不能为闪回表服务。
                被闪回的表必须启用行移动功能 alter table test_user.tt  enable row movement;
                flashback table 命令的执行者必须有  flashback any table 系统权限或被闪回表上由  flashback 对象权限
                flashback table 属于 ddl 命令,所有自带 提交功能。必须有该表的 select insert delete alter 权限。
                sys 用户的任何表无法使用该功能。
  闪回表的语法:
   flashback table [schema.] <table_name> to
   {[before drop [rename to table] | [SCN | TIMESTAMP] expr [enable | disable] triggers}
  参数:
      to scn:系统改变号,可以在 flashback_transaction_query 数据字典中查到。
      enable triggers:表示触发器恢复以后为ENABLE状态,默认为 disable状态
     
            启用 行移动功能
  alter table test_user.tt enable row movement;
            闪回10分钟前:
                flashback table test_user.tt to timestamp(systimestamp  - interval  '10'minute);
             闪回到SCN为 123456的时候:
               flashback table test_user.tt to scn 123456;
             将两表同时闪回到SCN为654321的时候
               flashback table test_user.tt,test_user.tb to scn 654321;
              
      闪回删除表(flashback drop);
            指的是撤销 drop table 效果。命令为 :flashback table ...to before drop;
           因为执行 drop table 命令时,表及其索引并没有被真正删除,其所占用的空间(段)只是分配给了另一种数据库对象:即回收站对象。
           并且这种所谓的分配使数据和数据块没有发生任何移动,而是还是待在原来的数据文件及其表空间中。
           查看回收站 dba_recyclebin 视图   查看自己的回收站 show recyclebin      然后可进一步查看回收站对象 :
           select * from ”回收站中的 recyclebin name字段对应的值“;
           将回收站对象取出,并重命名
           flashback table tt to before drop rename to tt_old_name; ---这里的tt 可以直接是原表名也可以是回收站中的对象名。
           表空间在自动增长的压力下会按照先入先出的原则将回收站对象的区分配给需要空间的段,将在回收站对象耗尽之前数据文件是不会
           自动增长的,反之,如果数据文件自动增长了,那么在其内的所有回收站对象将全部失效。
          
           查询哪些回收站对象因为属于自身的区被别的段占用了不能再回到被DROP之前了。
           SELECT OWNER,OBJECT_NAME ,ORIGINAL_NAME FROM DBA_RECYCLEBIN WHERE CAN_UNDROP='NO';
          
           跳过或清空回收站
           DROP TABLE TT PURGE; ---即采用 purge 命令让 drop 不产生回收站对象。
           purge table "回收站中的对象名";---删除特定的回收站对象
           purge user_recyclebin ;---删除当前用户的回收站中的所有对象。
           purge dba_recyclebin;---删除数据库中所有的回收站中的所有对象。
           禁用回收站功能
           alter system set recyclebin='off' scope='spfile';
          
    闪回数据库:
              闪回数据库的命令为 FLASHBACK DATABASE TO <PIT> ;  PIT:可以是SCN、时间 或还原点。是不完全恢复的一种。
              闪回数据库使用 闪回日志和重做日志。闪回日志就像是重做日志的反作用力,它记载的正好与重做日志的记录相反。
              在发起闪回操作时,根据写入闪回日志的反顺序,即先写后读的顺序,将闪回记录从闪回日志中读出并执行器记录的
              变更。闪回日志的保存路径一定是快速恢复区的子目录,保存期限由 参数 db_flashback_retention_target 控制(单位是分钟)
              ,只要超出保存期限将会在快速恢复区空间紧张的时候被自动删除。闪回数据库的数据库必须运行在归档模式下。
              设置保存闪回日志为2小时
               alter system set db_flashback_retention_target=120;
               查看闪回日志是否启用
               select flashback_on from v$database;
               启用闪回日志
               alter database flashback on
              
               在进入 MOUNT 状态执行  flashback database to scn ... 或 flashback database to  timestamp...;
              
  语法;
   flashback [standby] database <database_name>
   { to [scn |timestamp] <exp> | to before [scn | timestamp] <exp>}
   参数:
      standby: 指定恢复备用的数据库到某个 SCN 或某个时间点上。如果省略该子项,则数据库可能是主数据库,也可能
    是备用数据库。如果不省略该项,而没有备用数据库,则系统会返回一个错误。
      to scn <exp> 指定一个系统改变号SCN
      TO BEFORE SCN<exp>:恢复到之前的SCN
      to timestamp: 需要恢复的时间变大嫂
        to before timestamp:恢复数据库到之前的时间表达式。

               闪回数据库操作的两种可能性方式:Tc为当前时间点,Tr为还原点 ( Tc>Tr)
               第一种方式:
                1、利用闪回日志将数据库从Tc 倒推到比Tr 跟旧的某个时刻T2
                2、利用重做日志将数据库从T2 前滚到Tr。
               
                第二种方式:
                    1、确定一个比Tr更旧的时刻T2;
                    2、对于闪回日志根本无法恢复的对象或数据,令当初此类对象第一次产生的时间为T3,利用T3到T2的重做日志将其
                            重新产生并恢复。
                    3、利用闪回日志将数据库从Tc 倒推到T2时刻
                    4、利用重做日志将数据库从T2 前滚到Tr
                   
              闪回数据库实例:
                    1、先查看 v$flashback_databae_log视图,检查能够闪回到哪里
                     SELECT oldest_flashback_scn, to_char(oldest_flashback_time,'YYYY-MM-DD HH24:MI:SS')
                        FROM  v$flashback_database_log;
                    2、进入MOUNT 状态发起闪回数据库命令操作
                        startup force mount;
                        flashback database to scn 123456;
                        alter database open read only;
                     3、如果不满意返回的指定时刻,可以反复执行 第二步(指定闪回的还原点),
                            如果满意则:
                            ALTER DATABASE OPEN RESETLOGS;
                
  与闪回数据库相关的视图
   v$database 用来显示闪回数据库是否启动还是关闭,即是否被激活
   v$flashback_database_log   查看与闪回数据库有关的SCN,TIME及闪回数据库的时间,闪回数据的大小
   v$flashback_database_stat 显示闪回数据库日志的情况,可以用来估算闪回数据库潜在的需求空间。

 

你可能感兴趣的:(Oracle 闪回技术)