热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

Oracle11g之LogMiner常用案例

1LogMiner案例EnableSupplementalLoggingExtractaLogMinerDictionary(unlessyouplantousetheonlinecatalog)SpecifyRedoLogFilesforAnalysisStartLogMinerQueryV$LOGMNR_CONTENTSEndtheLogMinerSession1.1显式指定重做日志文

1 LogMiner 案例 Enable Supplemental Logging Extract a LogMiner Dictionary(unless you plan to use the online catalog) Specify Redo Log Files for Analysis Start LogMiner Query V$LOGMNR_CONTENTS End the LogMiner Session 1.1 显式指定重做日志文

1 LogMiner案例
  • Enable Supplemental Logging

  • Extract a LogMiner Dictionary(unless you plan to use the online catalog)

  • Specify Redo Log Files for Analysis

  • Start LogMiner

  • Query V$LOGMNR_CONTENTS

  • End the LogMiner Session

1.1 显式指定重做日志文件的LogMiner实例

本节内容必须开启最小补充日志:

SQL> ALTER DATABASE ADD SUPPLEMENTAL LOG DATA;

另外有些实例用到日期格式,这里事先设置日期格式:

SQL> ALTER SESSION SET NLS_DATE_FORMAT = 'dd-mon-yyyy hh24:mi:ss';

1.1.1 查询最新归档重做文件中所有的更改操作

最简单的检查数据库的修改历史是在源数据库中使用在线联机日志来解析重做日志文件,本节案例找出了数据库生成的最后的归档日志中的所有的修改操作(假定该数据不是RAC数据库)。

1.查找最新归档的重作日志。

SQL> SELECT NAME FROM V$ARCHIVED_LOG WHERE FIRST_TIME = (SELECT MAX(FIRST_TIME) FROM V$ARCHIVED_LOG);

2.添加重做日志文件

SQL> EXECUTE DBMS_LOGMNR.ADD_LOGFILE( -

 LOGFILENAME => '/usr/oracle/data/db1arch_1_16_482701534.dbf', -

 OPTIOnS=> DBMS_LOGMNR.NEW);

3.开始分析

SQL> EXECUTE DBMS_LOGMNR.START_LOGMNR( -

     OPTIOnS=> DBMS_LOGMNR.DICT_FROM_ONLINE_CATALOG);

4.查询结果

SQL> SELECT username AS USR, (XIDUSN || '.' || XIDSLT || '.' ||  XIDSQN) AS XID,

   SQL_REDO, SQL_UNDO FROM V$LOGMNR_CONTENTS WHERE username IN ('HR', 'OE');

5.关闭LogMiner会话

SQL> EXECUTE DBMS_LOGMNR.END_LOGMNR();

1.1.2 查询提交事务中的DML语句

如上节所示,默认情况下LogMiner显示重做日志文件中所有的修改操作,不管事务是否提交,由上节查询结果可知属于同一事务DML语句没有罗列在一起,查询结果不那么易读。虽然可以使用SQL来控制想要的输出结果,但是LogMiner提供了一个更简单的方法。在这个例子中,最新的归档重做日志文件将再次被分析,但它将只返回提交的事务。

除了分析步骤,其他步骤与上节完全一样,分析语句如下:

SQL>EXECUTE DBMS_LOGMNR.START_LOGMNR( -

    OPTIOnS=> DBMS_LOGMNR.DICT_FROM_ONLINE_CATALOG + -

    DBMS_LOGMNR.COMMITTED_DATA_ONLY); 

1.1.3 重构SQL语句

如果想输出的结果更为直观易读,可以通过指定PRINT_PRETTY_SQL参数来美化输出结果。

SQL> EXECUTE DBMS_LOGMNR.START_LOGMNR(-

   OPTIOnS=> DBMS_LOGMNR.DICT_FROM_ONLINE_CATALOG + -

              DBMS_LOGMNR.COMMITTED_DATA_ONLY + -

              DBMS_LOGMNR.PRINT_PRETTY_SQL);

1.1.4 使用重作日志文件中的LogMiner字典

当LogMiner字典存于在线联机日志文件中,必须在源数据库分析重做日志文件,而当LogMiner字典存于重作日志文件中,就可以在不同的数据库分析重做日志文件。

1.查找最新归档的重作日志。

SQL> SELECT NAME FROM V$ARCHIVED_LOG WHERE FIRST_TIME = (SELECT MAX(FIRST_TIME) FROM V$ARCHIVED_LOG);

2.查找包含字典的重做日志文件

  • 查找包含字典提取结束的重做日志文件

SQL> SELECT NAME, SEQUENCE#, DICTIONARY_BEGIN d_beg, DICTIONARY_END d_end FROM V$ARCHIVED_LOG WHERE SEQUENCE# = 

   (SELECT MAX (SEQUENCE#) FROM V$ARCHIVED_LOG WHERE DICTIONARY_END = &#39;YES&#39; and SEQUENCE# <= 210);

  • 查找包含字典提取开始的重做日志文件

SQL> SELECT NAME, SEQUENCE#, DICTIONARY_BEGIN d_beg, DICTIONARY_END d_end 

    FROM V$ARCHIVED_LOG WHERE SEQUENCE# = (SELECT MAX (SEQUENCE#) 
 
   FROM V$ARCHIVED_LOG WHERE DICTIONARY_BEGIN = &#39;YES&#39; and SEQUENCE# <= 208);

  • 添加重做日志文件
SQL> EXECUTE DBMS_LOGMNR.ADD_LOGFILE(-

    LOGFILENAME => &#39;/usr/oracle/data/db1arch_1_210_482701534.dbf&#39;, -

       OPTIOnS=> DBMS_LOGMNR.NEW);

SQL> EXECUTE DBMS_LOGMNR.ADD_LOGFILE(-

   LOGFILENAME => &#39;/usr/oracle/data/db1arch_1_208_482701534.dbf&#39;);

SQL> EXECUTE DBMS_LOGMNR.ADD_LOGFILE(-

   LOGFILENAME => &#39;/usr/oracle/data/db1arch_1_207_482701534.dbf&#39;);
  • 通过V$LOGMNR_LOGS查询重做日志文件分析列表

SQL> SELECT FILENAME AS name, LOW_TIME, HIGH_TIME FROM V$LOGMNR_LOGS;

3.开始分析

SQL> EXECUTE DBMS_LOGMNR.START_LOGMNR(-

   OPTIOnS=> DBMS_LOGMNR.DICT_FROM_ONLINE_CATALOG + -

              DBMS_LOGMNR.COMMITTED_DATA_ONLY + -

              DBMS_LOGMNR.PRINT_PRETTY_SQL);

4.查询分析结果

SQL> SELECT USERNAME AS usr, SQL_REDO FROM V$LOGMNR_CONTENTS 

   WHERE SEG_OWNER IS NULL OR SEG_OWNER NOT IN (&#39;SYS&#39;, &#39;SYSTEM&#39;) AND

   TIMESTAMP > &#39;10-jan-2003 15:59:53&#39;;

5.关闭LogMiner会话

SQL> EXECUTE DBMS_LOGMNR.END_LOGMNR();

1.1.5 跟踪内部字典的DDL语句

其他步骤与上节相同,唯一不同的事步骤3开始分析,如下:

SQL> EXECUTE DBMS_LOGMNR.START_LOGMNR(-

   OPTIOnS=> DBMS_LOGMNR.DICT_FROM_REDO_LOGS + -

              DBMS_LOGMNR.DDL_DICT_TRACKING + -

              DBMS_LOGMNR.COMMITTED_DATA_ONLY + -

              DBMS_LOGMNR.PRINT_PRETTY_SQL);

1.1.6 通过时间范围过滤输出

前面的例子中都是通过查询分析结果的时间限定的SQL子句来过滤输出结果,然而有一个更高效的方法来达到这个目的,这就是通过指定DBMS_LOGMNR.START_LOGMNR的时间范围。

1.创建重做日志列表

--

-- my_add_logfiles

-- Add all archived logs generated after a specified start_time.

--

CREATE OR REPLACE PROCEDURE my_add_logfiles (in_start_time  IN DATE) AS

  CURSOR  c_log IS

    SELECT NAME FROM V$ARCHIVED_LOG

      WHERE FIRST_TIME >= in_start_time;

count      pls_integer := 0;

my_option  pls_integer := DBMS_LOGMNR.NEW;

BEGIN

  FOR c_log_rec IN c_log

  LOOP

    DBMS_LOGMNR.ADD_LOGFILE(LOGFILENAME => c_log_rec.name,

                            OPTIOnS=> my_option);

    my_option := DBMS_LOGMNR.ADDFILE;

    DBMS_OUTPUT.PUT_LINE(&#39;Added logfile &#39; || c_log_rec.name);

  END LOOP;

END;

/

EXECUTE my_add_logfiles(in_start_time => &#39;13-jan-2003 14:00:00&#39;);

2.查询V$LOGMNR_LOGS确定重做日志文件列表

SQL> SELECT FILENAME name, LOW_TIME start_time, FILESIZE bytes

    FROM V$LOGMNR_LOGS;

3.调整重做日志列表

假定要分析的时产生于3 p.m.到4 p.m的重做日志文件:

SQL> EXECUTE DBMS_LOGMNR.START_LOGMNR(-

   STARTTIME => &#39;13-jan-2003 15:00:00&#39;, -

   ENDTIME   => &#39;13-jan-2003 16:00:00&#39;, -

   OPTIOnS=> DBMS_LOGMNR.DICT_FROM_ONLINE_CATALOG + -

                DBMS_LOGMNR.COMMITTED_DATA_ONLY + -

                DBMS_LOGMNR.PRINT_PRETTY_SQL);

4.查询V$LOGMNR_CONTENTS

SQL> SELECT TIMESTAMP, (XIDUSN || &#39;.&#39; || XIDSLT || &#39;.&#39; || XIDSQN) 

     AS XID, SQL_REDO FROM V$LOGMNR_CONTENTS WHERE SEG_OWNER = &#39;OE&#39;;

5.关闭LogMiner会话

SQL> EXECUTE DBMS_LOGMNR.END_LOGMNR();

1.2 未指定重做日志文件列表的LogMiner实例

上一节的诸多实例都是显式指定要分析的重做日志文件或者归档文件,但是,对于同一数据库生成的重做日志文件,可以通过指定时间或者SCN范围来确定要分析的重做日志列表,这个可以通过使用DBMS_LOGMNR.START_LOGMNR过程的DBMS_LOGMNR.CONTINUOUS_MINE来完成。

1.2.1 在给定的时间范围内分析重做日志

1.确定包含数据字典起始的重做日志文件时间戳

SQL> SELECT NAME, FIRST_TIME FROM V$ARCHIVED_LOG WHERE SEQUENCE# = (SELECT MAX(SEQUENCE#)

  &#160;FROM V$ARCHIVED_LOG WHERE DICTIONARY_BEGIN = &#39;YES&#39;);

2.查出该时间戳到现在所有的重做日志

该步骤不是必须的,但是它可以用来证明CONTINUOUS_MINE是按预期来进行的,用来步骤4作对比。

SQL> SELECT FILENAME name FROM V$LOGMNR_LOGS WHERE LOW_TIME > &#39;10-jan-2003 12:01:34&#39;;

3.开始分析

SQL> EXECUTE DBMS_LOGMNR.START_LOGMNR(-

   STARTTIME => &#39;10-jan-2003 12:01:34&#39;, -

     ENDTIME => SYSDATE, -

     OPTIOnS=> DBMS_LOGMNR.DICT_FROM_REDO_LOGS + -

                DBMS_LOGMNR.COMMITTED_DATA_ONLY + -

                DBMS_LOGMNR.PRINT_PRETTY_SQL + -

                    DBMS_LOGMNR.CONTINUOUS_MINE);

4.查询V$LOGMNR_LOGS

该步骤用来显示带有CONTINUOUS_MINE参数的DBMS_LOGMNR.START_LOGMNR过程所执行的所有的重做日志文件,参见步骤2.

SQL> SELECT FILENAME name FROM V$LOGMNR_LOGS;

5.查询V$LOGMNR_CONTENTS

SQL> SELECT USERNAME AS usr,(XIDUSN || &#39;.&#39; || XIDSLT || &#39;.&#39; || XIDSQN) as XID, SQL_REDO 

    FROM V$LOGMNR_CONTENTS WHERE SEG_OWNER IS NULL OR SEG_OWNER NOT IN (&#39;SYS&#39;, &#39;SYSTEM&#39;) AND TIMESTAMP > &#39;10-jan-2003 15:59:53&#39;;

6.关闭LogMiner会话

SQL> EXECUTE DBMS_LOGMNR.END_LOGMNR();

1.2.2 在给定的SCN范围内分析重做日志

1.确定上一检查点的SCN

SQL> SELECT CHECKPOINT_CHANGE#, CURRENT_SCN FROM V$DATABASE;

2.开始LogMiner并指定CONTINUOUS_MINE

SQL> EXECUTE DBMS_LOGMNR.START_LOGMNR(-

   STARTSCN => 56453576, -

   ENDSCN   => 56454208, -

   OPTIOnS=> DBMS_LOGMNR.DICT_FROM_ONLINE_CATALOG + -

               DBMS_LOGMNR.COMMITTED_DATA_ONLY + -

               DBMS_LOGMNR.PRINT_PRETTY_SQL + -

               DBMS_LOGMNR.CONTINUOUS_MINE);

3.查询LogMiner中的重做日志列表

SQL> SELECT FILENAME name, LOW_SCN, NEXT_SCN FROM V$LOGMNR_LOGS;

请注意,LogMiner添加的重做日志文件不包括整个SCN范围,当用指定CONTINUOUS_MINE参数来执行DBMS_LOGMNR.START_LOGMNR时,LogMiner仅仅是添加归档日志。根据查询需要,LogMiner会自动添加SCN范围内其他的在线重做日志,用如下的SQL来确定最新的归档文件中是否包含了该重做日志文件。

SQL> SELECT NAME FROM V$ARCHIVED_LOG

   WHERE SEQUENCE# = (SELECT MAX(SEQUENCE#) FROM V$ARCHIVED_LOG);

4.查询V$LOGMNR_CONTENTS

该查询不返回1.6.1911事务的SET TRANSACTION READ WRITE和COMMIT语句,因为这些语句没有SEG_OWNER。

SQL> SELECT SCN, (XIDUSN || &#39;.&#39; || XIDSLT || &#39;.&#39; ||  XIDSQN) as XID, SQL_REDO FROM V$LOGMNR_CONTENTS WHERE SEG_OWNER NOT IN (&#39;SYS&#39;, &#39;SYSTEM&#39;);

5.关闭LogMiner会话

SQL> EXECUTE DBMS_LOGMNR.END_LOGMNR();

1.2.3 在包含未来&#20540;的查询中使用连续分析

指定一个查询到指定的时间或者SCN才停止,可以通过设置DBMS_LOGMNR.START_LOGMNR的CONTINUOUS_MINE参数和设置一个未来时间点的ENDTIME或未来的ENDSCN参数来达到目的。

下面的例子,假设你想使用在线字典来监控hr.employees表现在开始到5小时后所有的变化,

1.开始LogMiner

SQL> EXECUTE DBMS_LOGMNR.START_LOGMNR(-

   STARTTIME => SYSDATE, -

   ENDTIME   => SYSDATE + 5/24, -

   OPTIOnS=> DBMS_LOGMNR.CONTINUOUS_MINE  + -

                DBMS_LOGMNR.DICT_FROM_ONLINE_CATALOG);

2.查询V$LOGMNR_CONTENTS

该查询操作直到查到指定的时间范围内(5小时后)生成的第一个重做日志文件记录才会停止,当然你也可以通过Ctrl&#43;C结束查询。本例中“SET ARRAYSIZE”语句使得查询结果&#26684;式可以跟它在重做日志文件中一样,如果不这样设置,那么查询结果的SQL会填满行才换行,不够美观易读。

SQL> SET ARRAYSIZE 1;

SQL> SELECT USERNAME AS usr, SQL_REDO FROM V$LOGMNR_CONTENTS WHERE  SEG_OWNER = &#39;HR&#39; AND TABLE_NAME = &#39;EMPLOYEES&#39;;

3.停止LogMiner

SQL> EXECUTE DBMS_LOGMNR.END_LOGMNR();

本文参阅Oracle官方文档翻译,不足之处欢迎批评指正!


推荐阅读
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • 本文详细介绍了在ASP.NET中获取插入记录的ID的几种方法,包括使用SCOPE_IDENTITY()和IDENT_CURRENT()函数,以及通过ExecuteReader方法执行SQL语句获取ID的步骤。同时,还提供了使用这些方法的示例代码和注意事项。对于需要获取表中最后一个插入操作所产生的ID或马上使用刚插入的新记录ID的开发者来说,本文提供了一些有用的技巧和建议。 ... [详细]
  • ubuntu用sqoop将数据从hive导入mysql时,命令: ... [详细]
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • 如何去除Win7快捷方式的箭头
    本文介绍了如何去除Win7快捷方式的箭头的方法,通过生成一个透明的ico图标并将其命名为Empty.ico,将图标复制到windows目录下,并导入注册表,即可去除箭头。这样做可以改善默认快捷方式的外观,提升桌面整洁度。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • Windows下配置PHP5.6的方法及注意事项
    本文介绍了在Windows系统下配置PHP5.6的步骤及注意事项,包括下载PHP5.6、解压并配置IIS、添加模块映射、测试等。同时提供了一些常见问题的解决方法,如下载缺失的msvcr110.dll文件等。通过本文的指导,读者可以轻松地在Windows系统下配置PHP5.6,并解决一些常见的配置问题。 ... [详细]
  • 本文介绍了在Win10上安装WinPythonHadoop的详细步骤,包括安装Python环境、安装JDK8、安装pyspark、安装Hadoop和Spark、设置环境变量、下载winutils.exe等。同时提醒注意Hadoop版本与pyspark版本的一致性,并建议重启电脑以确保安装成功。 ... [详细]
  • 使用在线工具jsonschema2pojo根据json生成java对象
    本文介绍了使用在线工具jsonschema2pojo根据json生成java对象的方法。通过该工具,用户只需将json字符串复制到输入框中,即可自动将其转换成java对象。该工具还能解析列表式的json数据,并将嵌套在内层的对象也解析出来。本文以请求github的api为例,展示了使用该工具的步骤和效果。 ... [详细]
  • HDFS2.x新特性
    一、集群间数据拷贝scp实现两个远程主机之间的文件复制scp-rhello.txtroothadoop103:useratguiguhello.txt推pushscp-rr ... [详细]
  • 仙贝旅行是日本最大的旅游服务平台之一,为广大用户提供优质的日本定制游服务。随着用户数量的增长,仙贝旅行决定与智齿科技合作,全面替换原有客服系统,打造全新的在线客服体系。该体系具备多渠道快速接入的能力,让仙贝旅行轻松与各个渠道的接入用户完成沟通。同时,机器人与人工协同发力,提升客户服务水平。 ... [详细]
  • 本文介绍了一些Java开发项目管理工具及其配置教程,包括团队协同工具worktil,版本管理工具GitLab,自动化构建工具Jenkins,项目管理工具Maven和Maven私服Nexus,以及Mybatis的安装和代码自动生成工具。提供了相关链接供读者参考。 ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了StartingzookeeperFAILEDTOSTART相关的知识,希望对你有一定的参考价值。下载路径:https://ar ... [详细]
  • 本文介绍了在Linux下安装和配置Kafka的方法,包括安装JDK、下载和解压Kafka、配置Kafka的参数,以及配置Kafka的日志目录、服务器IP和日志存放路径等。同时还提供了单机配置部署的方法和zookeeper地址和端口的配置。通过实操成功的案例,帮助读者快速完成Kafka的安装和配置。 ... [详细]
  • SAP羞辱国产软件商:技术停在10年前
    SAP中国研究院总裁芮祥麟表示,国产软件厂商过于热衷概念炒作,技术水平停留在10年前的客户端架构水平。他认为,国内厂商推出基于SOA的产品或转型SAAS模式是不可能的,研发新架构需要时间。当前最热门的概念是云计算,芮祥麟呼吁国产厂商应该潜心研发底层架构。 ... [详细]
author-avatar
huineisuan111184
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有