Oracle 11g之LogMiner常用案例

2024-05-10 06:18

本文主要是介绍Oracle 11g之LogMiner常用案例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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 = 'YES' 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 = 'YES' and SEQUENCE# <= 208);

  • 添加重做日志文件
SQL> EXECUTE DBMS_LOGMNR.ADD_LOGFILE(-LOGFILENAME => '/usr/oracle/data/db1arch_1_210_482701534.dbf', -OPTIONS => DBMS_LOGMNR.NEW);SQL> EXECUTE DBMS_LOGMNR.ADD_LOGFILE(-LOGFILENAME => '/usr/oracle/data/db1arch_1_208_482701534.dbf');SQL> EXECUTE DBMS_LOGMNR.ADD_LOGFILE(-LOGFILENAME => '/usr/oracle/data/db1arch_1_207_482701534.dbf');
  • 通过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 ('SYS', 'SYSTEM') ANDTIMESTAMP > '10-jan-2003 15:59:53';

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) ASCURSOR  c_log ISSELECT NAME FROM V$ARCHIVED_LOGWHERE FIRST_TIME >= in_start_time;count      pls_integer := 0;my_option  pls_integer := DBMS_LOGMNR.NEW;BEGINFOR c_log_rec IN c_logLOOPDBMS_LOGMNR.ADD_LOGFILE(LOGFILENAME => c_log_rec.name,OPTIONS => my_option);my_option := DBMS_LOGMNR.ADDFILE;DBMS_OUTPUT.PUT_LINE('Added logfile ' || c_log_rec.name);END LOOP;END;/EXECUTE my_add_logfiles(in_start_time => '13-jan-2003 14:00:00');

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

SQL> SELECT FILENAME name, LOW_TIME start_time, FILESIZE bytesFROM V$LOGMNR_LOGS;

3.调整重做日志列表

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

SQL> EXECUTE DBMS_LOGMNR.START_LOGMNR(-STARTTIME => '13-jan-2003 15:00:00', -ENDTIME   => '13-jan-2003 16:00:00', -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 || '.' || XIDSLT || '.' || XIDSQN) AS XID, SQL_REDO FROM V$LOGMNR_CONTENTS WHERE SEG_OWNER = 'OE';

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#)FROM V$ARCHIVED_LOG WHERE DICTIONARY_BEGIN = 'YES');

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

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

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

3.开始分析

SQL> EXECUTE DBMS_LOGMNR.START_LOGMNR(-STARTTIME => '10-jan-2003 12:01:34', -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 || '.' || XIDSLT || '.' || XIDSQN) as XID, SQL_REDO FROM V$LOGMNR_CONTENTS WHERE SEG_OWNER IS NULL OR SEG_OWNER NOT IN ('SYS', 'SYSTEM') AND TIMESTAMP > '10-jan-2003 15:59:53';

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_LOGWHERE 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 || '.' || XIDSLT || '.' ||  XIDSQN) as XID, SQL_REDO FROM V$LOGMNR_CONTENTS WHERE SEG_OWNER NOT IN ('SYS', 'SYSTEM');

5.关闭LogMiner会话

SQL> EXECUTE DBMS_LOGMNR.END_LOGMNR();

1.2.3 在包含未来值的查询中使用连续分析

   指定一个查询到指定的时间或者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+C结束查询。本例中“SET ARRAYSIZE”语句使得查询结果格式可以跟它在重做日志文件中一样,如果不这样设置,那么查询结果的SQL会填满行才换行,不够美观易读。

SQL> SET ARRAYSIZE 1;SQL> SELECT USERNAME AS usr, SQL_REDO FROM V$LOGMNR_CONTENTS WHERE  SEG_OWNER = 'HR' AND TABLE_NAME = 'EMPLOYEES';

3.停止LogMiner

SQL> EXECUTE DBMS_LOGMNR.END_LOGMNR();

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

这篇关于Oracle 11g之LogMiner常用案例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/975671

相关文章

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

python常用的正则表达式及作用

《python常用的正则表达式及作用》正则表达式是处理字符串的强大工具,Python通过re模块提供正则表达式支持,本文给大家介绍python常用的正则表达式及作用详解,感兴趣的朋友跟随小编一起看看吧... 目录python常用正则表达式及作用基本匹配模式常用正则表达式示例常用量词边界匹配分组和捕获常用re

Python get()函数用法案例详解

《Pythonget()函数用法案例详解》在Python中,get()是字典(dict)类型的内置方法,用于安全地获取字典中指定键对应的值,它的核心作用是避免因访问不存在的键而引发KeyError错... 目录简介基本语法一、用法二、案例:安全访问未知键三、案例:配置参数默认值简介python是一种高级编

MySQL中的索引结构和分类实战案例详解

《MySQL中的索引结构和分类实战案例详解》本文详解MySQL索引结构与分类,涵盖B树、B+树、哈希及全文索引,分析其原理与优劣势,并结合实战案例探讨创建、管理及优化技巧,助力提升查询性能,感兴趣的朋... 目录一、索引概述1.1 索引的定义与作用1.2 索引的基本原理二、索引结构详解2.1 B树索引2.2

从入门到精通MySQL 数据库索引(实战案例)

《从入门到精通MySQL数据库索引(实战案例)》索引是数据库的目录,提升查询速度,主要类型包括BTree、Hash、全文、空间索引,需根据场景选择,建议用于高频查询、关联字段、排序等,避免重复率高或... 目录一、索引是什么?能干嘛?核心作用:二、索引的 4 种主要类型(附通俗例子)1. BTree 索引(

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

Oracle 数据库数据操作如何精通 INSERT, UPDATE, DELETE

《Oracle数据库数据操作如何精通INSERT,UPDATE,DELETE》在Oracle数据库中,对表内数据进行增加、修改和删除操作是通过数据操作语言来完成的,下面给大家介绍Oracle数... 目录思维导图一、插入数据 (INSERT)1.1 插入单行数据,指定所有列的值语法:1.2 插入单行数据,指

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的

Python常用命令提示符使用方法详解

《Python常用命令提示符使用方法详解》在学习python的过程中,我们需要用到命令提示符(CMD)进行环境的配置,:本文主要介绍Python常用命令提示符使用方法的相关资料,文中通过代码介绍的... 目录一、python环境基础命令【Windows】1、检查Python是否安装2、 查看Python的安

python判断文件是否存在常用的几种方式

《python判断文件是否存在常用的几种方式》在Python中我们在读写文件之前,首先要做的事情就是判断文件是否存在,否则很容易发生错误的情况,:本文主要介绍python判断文件是否存在常用的几种... 目录1. 使用 os.path.exists()2. 使用 os.path.isfile()3. 使用