oracle闪回功能

 

oracle 闪回功能详解

分类: 数据库   729人阅读  评论(0)  收藏  举报
Oracle的闪回技术提供了一组功能,可以访问过去某一时间的数据并从人为错误中恢复。闪回技术是Oracle 数据库独有的,支持任何级别的恢复,包括行、事务、表和数据库范围。使用闪回特性,您可以查询以前的数据版本,还可以执行更改分析和自助式修复,以便在保持数据库联机的同时从逻辑损坏中恢复。

闪回技术包括以下特性: 
   (1)闪回查询允许用户查询过去某个时间点的数据,以重新构建由于意外删除或更改而丢失的数据。 
   (2)闪回版本查询提供了一种查看行级数据库随时间变化的方法。 
   (3)闪回事务查询提供了一种查看事务级数据库变化的方法。 
   (4)闪回数据库是进行时间点恢复的新策略。它能够快速将Oracle 数据库恢复到以前的时间,正确更正由于逻辑数据损坏或用户错误而引起的任何问题。
   (5)闪回表功能使 DBA 可以非常快速、轻松地将一个表或一组表恢复至过去特定的某一时间点。 
   (6)闪回删除在删除对象时提供了一个安全网,您可以非常快速、轻松地取消对一个表及其相关对象对象的删除。

  

  Flashback技术是以Undo Segment中的内容为基础的, 因此受限于UNDO_RETENTON参数。要使用flashback 的特性,必须启用自动撤销管理表空间。闪回参数如下:

  Connected to Oracle Database 11g Enterprise Edition Release 11.1.0.7.0 
  Connected as system@LOCAL_DB
  SQL> show parameter undo_
  NAME                                 TYPE        VALUE
  ------------------------------------ ----------- ------------------------------
  undo_management                      string      AUTO
  undo_retention                        integer     900    --默认是1440 即24*60,只保留一天的闪回数据,具体值在安装数据库实例时可以设置
  undo_tablespace                        string      UNDOTBS1
  

  

接下来讲讲oracle数据库闪回类型主要有三种:

  (1)闪回数据库(flashback database)

  闪回数据库就是当出现逻辑错误时,能够将整个数据库回退到出错前的那个状态。

  (2)闪回删除(flashback drop)

  Oracle10g之前,一旦删除了一个表,那么该表就会从数据字典里面删除。要恢复该表,需要进行不完全恢复。

  Oracle10g以后,当我们删除表时,默认Oracle只是在数据库字典里面对被删的表的进行了重命名,并没有真正的把表删除。

  (3)闪回表(flashback table)

  

  所谓闪回表,就是将表里的数据会退到历史上的某个时间点,例如回退到用户误删除数据之前的时间点,从而将误删除的数据恢复回来,在这个过程中,数据库仍然可用,而且不需要类似于闪回日志一样的额外空间。闪回表利用的是undo表空间里记录的数据被改变前的值,如果闪回表所需要的undo数据,由于保留的时间超过了初始化参数undo_retention所指定的值,从而导致该undo数据块被其他事务覆盖,就不能恢复到指定的时间点了。

  一、闪回数据库详解

  Flashback Database整个架构包括一个进程Recover Writer(RVWR)后台进程、Flashback Database Log日志和Flash Recovery Area。闪回数据库的实现机理是闪回日志,只要配置了闪回数据库,就会自动创建闪回日志。只要数据库里的数据发生变化,oracle会将数据修改前的旧值保存在闪回日志中。

  数据库的Flashback Database功能缺省是关闭的,要想启用这个功能,就需要做如下配置。

  (1)数据库配置为归档模式

  SQL> select log_mode from v$database; 
    LOG_MODE
    ------------
    NOARCHIVELOG

  SQL> archive log list;
    数据库日志模式             非存档模式
    自动存档             禁用
    存档终点            USE_DB_RECOVERY_FILE_DEST
    最早的联机日志序列     320
    当前日志序列           322
 1、启动归档为归档模式(其与将非归档模式转为归档模式步骤相似):

  (1)保存一致性,先关闭数据库 
   shutdown immediate ;
  (2)启动到mount阶段
   startup mount;
  (3)启动闪回功能
   alter database flashback on; --alter database archivelog;将数据库改为规定模式
  (4)切换到open阶段
   alter database open;
  (5)对数据做一个完整备份
   full backup --可以使用数据泵(expdp)或者使用RMAN
  

  启动闪回功能完善。

 2、配置闪回恢复区(flash recovery area FRA)

  SQL> show parameter db_recovery_file
  NAME                                 TYPE        VALUE
  ------------------------------------ ----------- ------------------------------
  db_recovery_file_dest                string      D:\app\flash_recovery_area
  db_recovery_file_dest_size           big integer 2G

   一般在安装数据库实例时,会让你选择是否开启oracle数据闪回功能,默认是开启的,安装过程中可以配置闪回路径以及闪回空间的大小。

 3、配置闪回保留时间

  SQL> show parameter db_flashback_retention_target
    NAME                                 TYPE        VALUE
    ------------------------------------ ----------- ------------------------------
    db_flashback_retention_target        integer     1440

    db_flashback_retention_target参数用来控制flashback log 数据保留的时间,默认值是1440,单位是minute,即24小时。

  4、启动数据库实例即可

  5、获取当前时间点和SCN

    SQL> select dbms_flashback.get_system_change_number from dual;
 
    GET_SYSTEM_CHANGE_NUMBER
    ------------------------
                    13081009
 
    SQL> select to_char(systimestamp,'yyyy-mm-dd HH24:MI:SS') as sysdt from dual;
 
    SYSDT
    -------------------
    2013-08-25 21:12:46
 
    SQL> truncate table dept;
    Table truncated

  Flashback Database 实际是对数据库的一个不完全恢复操作,因为需要关闭数据库重启到mount状态。

  

  SQL> shutdown immediate;

    数据库已经关闭。

   已经卸载数据库。

   ORACLE 例程已经关闭。

  SQL> startup mount;

  ORACLE 例程已经启动。

  Total System Global Area 1071333376 bytes

  Fixed Size                  1348508 bytes

  Variable Size             385879140 bytes

  Database Buffers          679477248

  bytes Redo Buffers                4628480 bytes

  数据库装载完毕。

  SQL> flashback database to timestamp to_timestamp('2013-08-25 21:12:46','yyyy-mm-dd HH24:MI:SS');

闪回完成。

 或者使用 SQL> flashback database to scn 13081009;

 在执行完flashback database 命令之后,oracle 提供了两种方式让你修复数据库: 
  1)直接alter database open resetlogs打开数据库,当然,指定scn或者timestamp时间点之后产生的数据统统丢失。
  2)先执行alter database open read only命令以read-only模式打开数据库,然后立刻通过逻辑导出的方式将误操作涉及表的数据导出,再执行recover database命令以重新应用数据库产生的redo,将数据库修复到flashback database 操作前的状态,然后再通过逻辑导入的方式,将之前误操作的表重新导入,这样的话对现有数据的影响最小,不会有数据丢失。

  SQL>alter database open read only;

  

查询被truncate的表,是否已经闪回数据。
  SQL> select deptno from dept;
  deptno
  ----------------------------------------
  0105206000001
  0105108040001
  0105304000001
  0105304010001
  010560001
  0105600010001
  0105601000001
  0105602000001

  证明闪回成功。

二、闪回删除
  Oracle10g以后,当我们删除表时,默认Oracle只是在数据库字典里面对被删的表的进行了重命名,并没有真正的把表删除。
  回收站(recyclebin):用来维护表被删除前的名字与删除后系统生成的名字之间的对应关系的数据字典,表上的相关对象(索引、触发器等)也会一并进入回收站。

  SQL> show parameter recycle
  NAME                                 TYPE        VALUE
  ------------------------------------ ----------- ------------------------------
  buffer_pool_recycle                  string      
  db_recycle_cache_size                big integer 0
  recyclebin                                                  on

实例一:闪回sys用户下的表 
SQL> select * from user_recyclebin;
OBJECT_NAME                    ORIGINAL_NAME                    OPERATION TYPE                      TS_NAME                        CREATETIME          DROPTIME               DROPSCN PARTITION_NAME                   CAN_UNDROP CAN_PURGE    RELATED BASE_OBJECT PURGE_OBJECT      SPACE
------------------------------ -------------------------------- --------- ------------------------- ------------------------------ ------------------- ------------------- ---------- -------------------------------- ---------- --------- ---------- ----------- ------------ ----------
SQL> drop table dept;
Table dropped
SQL> select * from user_recyclebin;
OBJECT_NAME                    ORIGINAL_NAME                    OPERATION TYPE                      TS_NAME                        CREATETIME          DROPTIME               DROPSCN PARTITION_NAME                   CAN_UNDROP CAN_PURGE    RELATED BASE_OBJECT PURGE_OBJECT      SPACE
------------------------------ -------------------------------- --------- ------------------------- ------------------------------ ------------------- ------------------- ---------- -------------------------------- ---------- --------- ---------- ----------- ------------ ----------
SQL>flashback table dept to before drop; --或者使用(flashback table dept to before drop rename to dept_bak;)
报如下错误:ORA-38305: 对象不在回收站中
原因:Flashback不支持sys用户与system表空间下的对象,也不能从回收站里拿到。故使用SYS或者SYSTEM用户登陆时,show recyclebin为空。
实例二:闪回非sys、system用户下的表
 SQL> drop table DEPT_BAK;

Table dropped
SQL> select * from user_recyclebin a where a.original_name = 'DEPT_BAK';
OBJECT_NAME                    ORIGINAL_NAME                    OPERATION TYPE                      TS_NAME                        CREATETIME          DROPTIME               DROPSCN PARTITION_NAME                   CAN_UNDROP CAN_PURGE    RELATED BASE_OBJECT PURGE_OBJECT      SPACE
------------------------------ -------------------------------- --------- ------------------------- ------------------------------ ------------------- ------------------- ---------- -------------------------------- ---------- --------- ---------- ----------- ------------ ----------
BIN$BnpnsFC8SfSYdJ7Qio0k2g==$0 DEPT_BAK                        DROP      TABLE                     TESTSPACE                      2013-04-21:15:38:04 2013-08-25:22:11:45   13087074                                  YES        YES           745783      745783       745783          8
SQL> flashback table DEPT_BAK to before drop;
Done

备注:

1、 禁用与启用recyclebin该功能:

SQL> alter system set recyclebin=off;

SQL> alter system set recyclebin=on;

禁用后删除的对象将直接删除,不会写到Recyclebin中,当然在删除时,指定purge参数,表也将直接删除,不会写到recyclebin中。

SQL> drop table name purge;

2)关于purge命令

  表空间的RecycleBin区域只是一个逻辑区域,而不是从表空间上物理的划出一块区域固定用于回收站,因此RecycleBin是和普通对象共用表空间的存储区域,或者说是RecycleBin的对象要和普通对象抢夺存储空间。当发生空间不够时,Oracle会按照先入先出的顺序覆盖RecycleBin中的对象。也可以手动的删除Recycle Bin占用的空间。

  1)Purge tablespace tablespace_name;  用于清空表空间的RecycleBin

  2)Purge tablespace tablespace_name user user_name;  清空指定表空间的Recycle Bin中指定用户的对象

  3)Purge recyclebin;  删除当前用户的Recycle Bin中的对象

  4)Purge dba_recyclebin  删除所有用户的Recycle Bin中的对象,该命令要sysdba权限

  5)Drop table table_name purge;  删除对象并且不放在Recycle Bin中,即永久的删除,不能用Flashback恢复。

  6)Purge index recycle_bin_object_name;  当想释放Recycle bin的空间,又想能恢复表时,可以通过释放该对象的index所占用的空间来缓解空间压力。因为索引是可以重建的。

三、闪回表
  查询过去某个时刻表的数据的情况,一旦确认某个时刻的数据满足我们的需求以后,可以根据这个时间执行闪回表。

  ORA-08189: 因为未启用行移动功能, 不能闪回表,需要先执行一个命令:ALTER TABLE dept ENABLE ROW MOVEMENT。
 语法一:
   select * from dept
   VERSIONS BETWEEN TIMESTAMP SYSTIMESTAMP - INTERVAL '1' DAY AND SYSTIMESTAMP -INTERVAL '1' HOUR;
 
 语法二:
   select * from dept as of timestamp to_timestamp('2013-08-25 21:12:46','yyyy-mm-dd HH24:MI:SS');
 
 语法三:
   select * from dept as of scn 13081009;
 
 语法四:
   select * from flashback_transaction_query a where a.table_name='DEPT';


附注:interval用法

Oracle语法:

INTERVAL '{ integer | integer time_expr | time_expr }' { { DAY | HOUR | MINUTE } [ ( leading_precision ) ] | SECOND [ ( leading_precision

[, fractional_seconds_precision ] ) ] } [ TO { DAY | HOUR | MINUTE | SECOND [ (fractional_seconds_precision) ] } ]

leading_precision值的范围是0到9, 默认是2. time_expr的格式为:HH[:MI[:SS[.n]]] or MI[:SS[.n]] or SS[.n], n表示微秒.

该类型与INTERVAL YEAR TO MONTH有很多相似的地方,建议先看INTERVAL YEAR TO MONTH再看该文.

INTERVAL '20' DAY - INTERVAL '240' HOUR = INTERVAL '10-0' DAY TO SECOND

表示: 20天 - 240小时 = 10天0秒

INTERVAL '30.12345' SECOND(2,4)   

表示: 30.1235秒, 因为该地方秒的后面精度设置为4, 要进行四舍五入.

查询tableA中10分钟前的数据(闪回查询,前提:undo没有被覆盖..如果undo被覆盖,查询会失败)

Select * From table dept As Of Timestamp (systimestamp - Interval '10' minute);


Oracle闪回体系  

2010-03-02 20:33:43|  分类: Oracle|举报|字号 订阅

在日常数据库使用过程中,用户往往因为误操作,例如 delete、update,并最终提交了修改。一般发生这样的情况我们只能采用逻辑备份或者物理备份进行恢复来纠正这样的错误,而这种方法极其复杂和低效。于是从oracle9i开始,逐渐引入了闪回的概念,10g,11g对闪回的功能进行了逐步的增加及功能的强化。
关键词:数据库;Oracle; flashback Undo
中图分类号:G43       文献标志码:A      文章编号:1001-7836(2008)12-0
作者简介:马青(1980-),女,河北邢台人,助教,从事软件应用研究。
        引言
        本文讨论oracle闪回技术的发展及实现方法,降低用户错误导致的数据丢失,提高数据库安全性,从oracle9i开始的11g的闪回功能的发展对闪回技术的使用进行探讨。
        一、闪回的发展
        从Oracle9i开始Oracle引入了闪回查询(Flashback Query)的特性,通过闪回查询我们可以按照时间戳或者SCN来向前查询,获取修改前的数据镜像,然后通过Insert等操作就可以恢复数据,闪回查询是一种基于回滚段存储的数据修改前的镜像。9i前只要事物被提交,修改前的数据镜像就会被覆盖,空间被重用,Oracle9i引入了AUM特性,也就是回滚段自动管理的新特性,从而我们可以通过设置undo_retention参数来控制UNDO信息的保留时间,只要UNDO信息被保留,闪回就可以实现。所有的闪回技术,除了闪回数据库,都是基于撤销数据(undodata)。
        Oracle9i仅仅有闪回查询的功能,到了oracle10g,闪回(flashback)功能有了全面的加强,现在几乎能够恢复所有的数据库错误(物理文件损害除外)。Oracle数据库10g提供了五个新的闪回功能:闪回版本(Versions)查询,闪回事务(Transaction)查询,闪回删除(Drop),闪回表(Table)和闪回数据库(Database)。上面五种功能可以分成三类。
        1.Flashback Database
        Flashback Database类似于按下数据库的倒带按钮,以当前数据库为起点,按照从后向前的时间顺序倒退所有的工作变化,最终的结果就像执行不完全恢复一样。闪回点以后的工作都将丢失,然后使用RESETLOGS命令打开数据库。这种闪回方法依赖于一个10g新增的后台进程,RVWR进程,此进程生成闪回日志,闪回数据库使用闪回日志就行闪回操作,闪回日志是自动管理和创建的。
        2.Flashback Query(Versions,Transaction,Table)
        此类恢复撤销数据,通过查询撤销数据把修改前的数据恢复回来。它所有的变化形式都依赖于撤销段的使用。
        3.Flashback Drop
        从10g开始drop table 命令被映射为rename命令,当发出drop table 命令的时候被删除的表被oracle数据库自动命名为另外一个名字仍旧保存在了数据库中。
        二、闪回技术的使用及发展
        闪回技术从9i到10g的发展和增强下面用实例的方式就行展示。
        1.Oracle9i的闪回查询功能
        Oracle9i的闪回查询只有一种方式,也就是根据一个时间点来找到该时间点的数据。首先确定一个时间点,例如使用scn,假设要找到scn=2232322的时间点的表tb1的数据:
        Select * from tb1 as of scn =2232322;这样得到数据,就是SCN号是2232322那个时刻的数据。在oracle9iR2版本中支持至少五分钟的Flashback query。
        2..Oracle10g的闪回查询功能
        上面提到oracle9iR2版本的数据库支持至少五分钟差距的闪回查询,到了10g支持三秒差距的闪回查询,虽然一般闪回的查询都会间隔较长的一个时间,不过从这一点上可以看出Oracle10g闪回查询有所增强。并且不仅仅在这一个方面,Oracle10g提供了四种不同类型的闪回查询。
        基本的Flashback Query,这个功能和oracle9i的基本类似,不过能够查询到的数据可以通过响应的配置参数进行控制,Flashback Table Query,这个功能很简单,oracle就是通过查询撤销段来抽取所有已变化记录的细节,然后再构造和执行能够倒退这些变化的语句,这种闪回操作是一个尽可能抵消先前所有事物影响的单独事物。表闪回查询需要启动row movement功能,Oracle10g>alter table tb1 enable row movement;
        Oracle10g>flashback table tb1 to timestamp(‘2009-02-10 12:11:10’, ‘yyyy-mm-dd hh24:mi:ss);
        通常情况下,表闪回会成功,但有一下原因有可能失败:
        a.如果在删除和闪回操作之间某个键值被重用,会违反主键约束。
        b.如果不存在足够的撤销信息,会引发ORA-08180错误。
        c.如果受闪回影响的任何记录被其他用户锁定,会引发ORA-00054错误。
        d.表定义在闪回期间不能发生变化,因此DDL语句不能闪回。
        e.SYS模式下的表不能闪回。
        3.Flashback Versions Query
        由于可能会有这样的情况发生,一条记录在生命周期内,会有多次发生变化的可能。Flashback Versions Query允许我们查看某条记录所有已提交的版本,注意是已提交。
        4.Flashback Transaction Query 
        和前面两种新特性不同的是,前面两种采用针对一个对象的撤销数据,而Flashback Transaction Query则采用了不同尺度来分析撤销数据,无论存在多少受某个事物影响的对象,这种方法都会检索针对这个事物的所有撤销数据。主要使用FLASHBACK_TRANSACTION_QUERY视图,接着上面Flashback Versions Query查询出来的事物号进行查询对应语句从而可以回退这个事物。从上面几个例子中可以看出10g的闪回功能已经很强了。能够帮助用户对不小心出现的操作上的失误进行处理。
        5.Oracle10g的Flashback Drop功能
        Flashback Drop功能使用更加灵活简单,对于误删表的操作可以很轻松的找回来。避免了使用数据库备份进行恢复
        操作很简单,不过需要强调2点,第一,Flashback drop不能恢复truncate命令,第二,不能恢复级联删除用户命令删除的表
        6.Oracle10g的Flashback Database功能
        如果说flashback query 可用来恢复指定时间点的记录,flashback table 可用来恢复被删除或指定时间点的表,而flashback database,则直接提供一个数据库级别的恢复,可将数据库恢复到指定的时间点,相对于前两者,其粒度是最大的,而且有一个单独闪回区域,存储闪回数据。必备的一些条件:A.数据库启用了flashback database。B.数据库必须打开了flash recovery area,如果数据库是RAC,flash recovery area 必须位于共享存储中。C.数据库必须处于archivelog 模式。
        使用闪回数据库的命令很简单,启动数据库到mount状态,SQL>alter database flashback on;
        打开数据库的闪回功能,闪回的时候也是一句命令:
        SQL>flashback database to scn 248739;或SQL>flashback database to timestamp(‘2009-02-12 15:11:30’,‘yyyy-mm-dd hh24:mi:ss);
        上面的SCN和timestamp都是指一个特定的时间点,也就是数据库要回复的那个时刻,然后执行SQL> alter database open read on ly;
        检查数据库数据,如果数据没有问题的话,执行下面的命令打开数据库SQL>alter database open resetlogs;
        闪回数据库不会恢复物理文件损坏导致的数据丢失,这时也只能使用传统的数据库恢复办法恢复数据库。
        7.Oracle11g的闪回功能
        11g的闪回功能延续了10g的功能,但有所增强,在11g以前的版本,Oracle的rman并没有和其他日志应用系统紧密结合起来,因此,当rman删除日志后,可能会发现其他的系统比如DA TA GUARD、STREAMS等由于日志被删除而无法正常工作。从11g开始,rman在删除时会首先判断,这个日志是否其他系统仍然需要,当其他需要仍然需要这个日志时,rman会报警,且不会删除这个日志。保证了闪回日志的完整性。
        总结
        经过对大量的停机原因研究发现,人为错误是导致停机的最大原因。人为错误包括:误删除重要数据;         UPDATE 语句中不正确的WHERE 子句更新了比预期更多的数据等。我们需要尽可能的防止人为错误,当预防措施失败后,要能够撤消以前操作并恢复数据,数据库闪回功能,在人为错误修正上取得了突破。 闪回是让管理员“倒回”数据库上的活动的一项功能。利用闪回技术,更正错误的时间与错误发生的时间几乎相同。它非常易用,使用一条短命令便可恢复整个数据库,而不必执行复杂的操作步骤,大大提高了数据安全性和完整性。

参考文献:
[1]Oracle? Database Administrator's Guide 10g Release 2.
[2]Oracle? Database Backup and Recovery Advanced User's Guide 10g Release 2 . 
[3]Oracle? Database Backup and Recovery Reference10g Release 2. 
[4]Oracle9i Database Administrator's Guide Release 2.
[5]Oracle? Database Backup and Recovery Reference 11g Release 1.
[6]Oracle? Database Backup and Recovery User's Guide 11g Release 1.

 

Oracle 闪回技术

分类: RMAN 对Oracle 备份与恢复 oracle 基本入门语法 ORACLE 基础知识   849人阅读  评论(0)  收藏 举报

---闪回技术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 显示闪回数据库日志的情况,可以用来估算闪回数据库潜在的需求空间。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值