ORACLE FLASHBACK的另类应用

简介:
 今天遇到了一个有些类似于“审计”的问题。
       因为在检查all_objects时发现有一张表的last_ddl_time发生了变化,为了防止是其结构发生变化,进而进行了检查。但是如果没有对原始表的结构记录,该如何处理呢?
        因为当时该数据库已经开启了FLASH BACK功能,所以通过这个线索来进行处理。
        进行如下方法:
      
select    tab_log_ver
as select *
    from tab_log as timestamp('2008-12-08 8:00:00', 'YYYY-MM-DD HH24:MI:SS') where rownum<5;
      
      然后比对tab_log_ver和tab_log字段没有发现不同。为防止判断有问题,又做了进一步的实验:
     
首先创建一张测试表:
SQL> desc test_log_ver
Name                Type                    Nullable Default Comments 
----------- ------------- -------- ------- -------- 
MESSAGE_ID    VARCHAR2(100)                                                     
TASK_ID         VARCHAR2(18)                                                        
SUBMIT_TIME VARCHAR2(14)    Y                                                 
TERMINAL_ID VARCHAR2(20)    Y                                                 
STATUS            CHAR(10)            Y
    
       然后开始修改该测试表的结构:
      
SQL> alter table test_log_ver modify (MESSAGE_ID varchar2(30));

Table altered

Executed in 0.125 seconds

SQL> alter table test_log_ver add(test_col number);

Table altered

Executed in 0 seconds

SQL> select object_name,
    2                 to_char(created, 'yyyy-mm-dd hh24:mi:ss') created,
    3                 to_char(last_ddl_time, 'yyyy-mm-dd hh24:mi:ss') last_ddl_time
    4        from user_objects
    5     where object_name = 'TEST_LOG_VER'
    6    ;

OBJECT_NAME      CREATED              LAST_DDL_TIME
---------------- -------------------  ---------------------
TEST_LOG_VER     2008-12-08 15:38:00  2008-12-08 15:46:15

Executed in 0.016 seconds

      试图检查修改之前的数据信息:
   
select * from test_log_ver as of timestamp
to_timestamp('2008-12-08 15:38:10', 'YYYY-MM-DD HH24:MI:SS')

ORA-01466: unable to read data - table definition has changed

      报ORA-01466错误。使用FLASHBACK TABLE来执行,同样的报错信息。
     
SQL> select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') SYSDATE from dual;

SYSDATE
-----------------------
2008-12-08 16:28:50

在16:28分时,执行FLASHBACK操作,并且指定的时间大于2008-12-08 15:46:15。

SQL> flashback    table XXX.test_log_ver to timestamp to_timestamp('2008-12-08 15:50:00', 'YYYY-MM-DD HH24:MI:SS');

Flashback complete.
成功执行!


       这里我们不难发现,如果结构发生改变,基于FLASH BACK的查询或者恢复都会有一定的问题,它只能恢复到修改后的时间点。毕竟FLASHBACK是为数据的快速恢复来设计使用的。
        但是可以在一定的程度上证明,数据结构没有发生改变的时间。否则就会报ORA-01466错误了。

        -:)

本文转自Be the miracle!博客51CTO博客,原文链接http://blog.51cto.com/miracle/117956如需转载请自行联系原作者


Larry.Yue

相关文章
|
2月前
|
存储 Oracle 关系型数据库
Oracle数据库的应用场景有哪些?
【10月更文挑战第15天】Oracle数据库的应用场景有哪些?
200 64
|
5月前
|
存储 Oracle 关系型数据库
关系型数据库Oracle应用场景
【7月更文挑战第5天】
170 3
|
2月前
|
SQL 存储 Oracle
Oracle数据库SQL语句详解与应用指南
在数字化时代,数据库已成为各类企业和组织不可或缺的核心组件。Oracle数据库作为业界领先的数据库管理系统之一,广泛应用于各种业务场景。掌握Oracle数据库的SQL语句是数据库管理员、开发人员及运维人员的基本技能。本文将详细介绍Oracle数据库SQL语句的基本概念、语法、应用及最佳实践。一、Or
86 3
|
5月前
|
Oracle 关系型数据库 数据处理
|
5月前
|
人工智能 Oracle 关系型数据库
Oracle数据库在哪些新兴领域有应用?
【7月更文挑战第21天】Oracle数据库在哪些新兴领域有应用?
135 1
|
7月前
|
SQL Oracle 关系型数据库
|
7月前
|
Oracle 关系型数据库 Shell
oracle的基本应用,持续完善中...
oracle的基本应用,持续完善中...
|
7月前
|
SQL Oracle 关系型数据库
oracle中wm_conocat()函数的应用
oracle中wm_conocat()函数的应用
79 1
|
7月前
|
SQL Oracle 关系型数据库
Oracle PL/SQL基础知识及应用案例
Oracle PL/SQL基础知识及应用案例
130 0
|
Oracle 关系型数据库 Java
分享一个 Oracle RAC 模式下客户端建立JDBC初始连接时因ONS造成应用启动时卡顿30秒问题的排查分析案例
分享一个 Oracle RAC 模式下客户端建立JDBC初始连接时因ONS造成应用启动时卡顿30秒问题的排查分析案例