Oracle查看LogMiner的详解

Oracle数据库查看日志的方法很多,我们可以根据SQL语句来实现,也可以通过日志查看工具LogMiner来实现,本文我们主要就介绍了这一过程,接下来就让我们一起来了解一下吧。
    
    一、Oracle日志的路径
    
    登录:sqlplus "/as sysdba"
    
    查看路径:SQL> select * from v$logfile;
    
    SQL> select * from v$logfile;(#日志文件路径)
    
    二、Oracle日志文件包含哪些内容
    
    1. control01.ctl example01.dbf redo02.log   sysaux01.dbf undotbs01.dbf
    
    2. control02.ctl redo03.log   system01.dbf users01.dbf
    
    3. control03.ctl redo01.log     SHTTEST.dbf temp01.dbf
    
    三、Oracle日志的查看方法
    
    SQL>select * from v$sql   (#查看最近所作的操作)
    
    SQL>select * fromv $sqlarea(#查看最近所作的操作)
    
    Oracle 数据库的所有更改都记录在日志中,从目前来看,分析Oracle日志的唯一方法就是使用Oracle公司提供的LogMiner来进行,因为原始的日志信息我们根本无法看懂,Oracle8i后续版本中自带了LogMiner,而LogMiner就是让我们看懂日志信息的工具,通过这个工具可以:查明数据库的逻辑更改,侦察并更正用户的误操作,执行事后审计,执行变化分析。
    
    四、LogMiner的使用
    
    1、创建数据字典文件(data-dictionary)
    
    1)。首先在init.ora初始化参数文件中,添加一个参数UTL_FILE_DIR,该参数值为服务器中放置数据字典文件的目录。如:UTL_FILE_DIR = ($ORACLE_HOMElogs) ,重新启动数据库,使新加的参数生效:
    
    SQL> shutdown;
    
    SQL>startup;
    
    2)。然后创建数据字典文件
    
    1. SQL> connect /as sysdba
    
    2. SQL> execute dbms_logmnr_d.build(dictionary_filename => ‘dict.ora‘,dictionary_location => ‘/data1/oracle/logs‘);
    
    3. PL/SQL procedure successfully completed
    
    2、创建要分析的日志文件列表
    
    1)。创建分析列表,即所要分析的日志
    
    1. SQL>execute dbms logmnr.add logfile(LogFileName => ‘/data1/oracle/oradata/akazamdb/redo01.log‘,Options => dbms_logmnr.new);
    
    2. PL/SQL procedure successfully completeds
    
    2)。添加分析日志文件,一次添加1个为宜
    
    1. SQL>execute dbms_ logmnr.add_ logfile(LogFileName => ‘/data1/oracle/oradata/akazamdb/redo01.log‘,Options => dbms_logmnr.ADDFILE);
    
    2. PL/SQL procedure successfully completed
    
    3、使用LogMiner进行日志分析(具体要查询什么内容可以自己修改)
    
    (1)无限制条件
    
    SQL> EXECUTE dbms_logmnr.start_logmnr(DictFileName=>‘/data1/oracle/logs/v816dict.ora ‘);
    
    (2)有限制条件
    
    通过对过程DBMS_ LOGMNR.START_LOGMNR中几个不同参数的设置,可以缩小要分析日志文件的范围。通过设置起始时间和终止时间参数我们可以限制只分析某一时间范围的日志。如下面的例子,我们仅仅分析2007年9月18日的日志:
    
    1. SQL> EXECUTE dbms_logmnr.start_logmnr(
    
    2. DictFileName => ‘ /data1/oracle/logs/ v816dict.ora ‘,
    
    3. StartTime => to_date(‘2007-9-18 00:00:00‘,‘YYYY-MM-DD HH24:MI:SS‘)
    
    4. EndTime => to_date(‘‘2007-9-18 23:59:59‘,‘YYYY-MM-DD HH24:MI:SS ‘));
    
    也可以通过设置起始SCN和截至SCN来限制要分析日志的范围:
    
    1. SQL> EXECUTE dbms_logmnr.start_logmnr(
    
    2. DictFileName => ‘ /data1/oracle/logs/ v816dict.ora ‘,
    
    3. StartScn => 20,
    
    4. EndScn => 50);

   4、观察分析结果(v$logmnr_contents)
    
    到现在为止,我们已经分析得到了重作日志文件中的内容。动态性能视图v$logmnr_contents包含LogMiner分析得到的所有的信息。SELECT sql_redo FROM v$logmnr_contents;
    
    如果我们仅仅想知道某个用户对于某张表的操作,可以通过下面的SQL查询得到,该查询可以得到用户DB_ZGXT对表SB_DJJL所作的一切工作。
    
    SQL> SELECT sql_redo FROM v$logmnr_contents WHERE username=‘DB_ZGXT‘ AND tablename=‘SB_DJJL‘;需要强调一点的是,视图v$logmnr_contents中的分析结果仅在我们运行过程‘dbms_logmrn.start_logmnr‘这个会话的生命期中存在。这是因为所有的LogMiner存储都在PGA内存中,所有其他的进程是看不到它的,同时随着进程的结束,分析结果也随之消失。最后,使用过程DBMS_LOGMNR.END_LOGMNR终止日志分析事务,此时PGA内存区域被清除,分析结果也随之不再存在。
    
    5、查看LogMiner工具分析结果
    
    1. SQL> select * from dict t where t.table_name like ‘%LOGMNR%‘;-看所有与logmnr相关的视图
    
    2. TABLE_NAME                       COMMENTS
    
    3. ------------------------------ --------------------------------------------------------------------------------
    
    4. GV$LOGMNR_CALLBACK               Synonym for GV_$LOGMNR_CALLBACK
    
    5. GV$LOGMNR_CONTENTS               Synonym for GV_$LOGMNR_CONTENTS
    
    6. GV$LOGMNR_DICTIONARY             Synonym for GV_$LOGMNR_DICTIONARY
    
    7. GV$LOGMNR_LOGFILE               Synonym for GV_$LOGMNR_LOGFILE
    
    8. GV$LOGMNR_LOGS                   Synonym for GV_$LOGMNR_LOGS
    
    9. GV$LOGMNR_PARAMETERS             Synonym for GV_$LOGMNR_PARAMETERS
    
    10. GV$LOGMNR_PROCESS               Synonym for GV_$LOGMNR_PROCESS
    
    11. GV$LOGMNR_REGION                 Synonym for GV_$LOGMNR_REGION
    
    12. GV$LOGMNR_SESSION               Synonym for GV_$LOGMNR_SESSION
    
    13. GV$LOGMNR_STATS                 Synonym for GV_$LOGMNR_STATS
    
    14. GV$LOGMNR_TRANSACTION           Synonym for GV_$LOGMNR_TRANSACTION
    
    15. V$LOGMNR_CALLBACK               Synonym for V_$LOGMNR_CALLBACK
    
    16. V$LOGMNR_CONTENTS               Synonym for V_$LOGMNR_CONTENTS
    
    17. V$LOGMNR_DICTIONARY             Synonym for V_$LOGMNR_DICTIONARY
    
    18. V$LOGMNR_LOGFILE                 Synonym for V_$LOGMNR_LOGFILE
    
    19. V$LOGMNR_LOGS                   Synonym for V_$LOGMNR_LOGS
    
    20. V$LOGMNR_PARAMETERS             Synonym for V_$LOGMNR_PARAMETERS
    
    21. V$LOGMNR_PROCESS                 Synonym for V_$LOGMNR_PROCESS
    
    22. V$LOGMNR_REGION                 Synonym for V_$LOGMNR_REGION
    
    23. V$LOGMNR_SESSION                 Synonym for V_$LOGMNR_SESSION
    
    24. TABLE_NAME                       COMMENTS
    
    25. ------------------------------ --------------------------------------------------------------------------------
    
    26. V$LOGMNR_STATS                   Synonym for V_$LOGMNR_STATS
    
    27. V$LOGMNR_TRANSACTION             Synonym for V_$LOGMNR_TRANSACTION
    
    GV$LOGMNR_LOGS 是分析日志列表视图,分析结果在GV$LOGMNR_CONTENTS 视图中,可按以下语句查询:
    
    1. select scn,timestamp,log_id,seg_owner,seg_type,table_space,data_blk#,
    
    2. data_obj#,data_objd#,session#,serial#,username,session_info,sql_redo,sql_undo
    
    3. from logmnr3 t where t.sql_redo like ‘create%‘;
    
    如果不能正常查询GV$LOGMNR_CONTENTS视图,并报以下错误,ORA-01306: 在从 v$logmnr_contents 中选择之前必须调用 dbms_logmnr.start_logmnr() .可采用如下方法:
    
    1. create table logmnr3 as select * from GV$LOGMNR_CONTENTS;
    
    关于Oracle数据库日志查看工具LogMiner的使用相关知识就介绍到这里了,希望本次的介绍能够对您有所收获!

时间: 2024-10-25 18:07:38

Oracle查看LogMiner的详解的相关文章

[强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!)

原文:[强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!) [强烈推荐]ORACLE PL/SQL编程详解之七: 程序包的创建与应用(聪明在于学习,天才在于积累!) ——通过知识共享树立个人品牌.   继上七篇:            [推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下)            [顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之

Linux安装Oracle JDK替换OpenJDK详解

Linux安装Oracle JDK替换OpenJDK详解 作者:旸仔发表于:2013-3-11分类:Linux 众所周知,由于Oracle公司的JDK的版权问题,大多数Linux发行版在安装时都会附带开源的无版权问题的OpenJDK,以支持某些 java程序软件.但是如果我们在Linux下做一些java语言的开发,很可能还是需要安装和使用Oracle公司的原版JDK(以下简称 “JDK”).如何安装JDK并替换掉OpenJDK呢?今天旸仔做一个详细的解答: 毋庸置疑,如果一个系统内同时存在一个以

oracle impdp的table_exists_action详解

oracle impdp的table_exists_action详解 分类: [oracle]--[备份与恢复]2012-01-06 22:44 9105人阅读 评论(0) 收藏 举报 tableactionoracleschemaobjectimport 1 table_exists_action参数说明 使用imp进行数据导入时,若表已经存在,要先drop掉表,再进行导入. 而使用impdp完成数据库导入时,若表已经存在,有四种的处理方式: 1)  skip:默认操作 2)  replace

oracle中imp命令详解 .

oracle中imp命令详解 Oracle的导入实用程序(Import utility)允许从数据库提取数据,并且将数据写入操作系统文件.imp使用的基本格式:imp[username[/password[@service]]],以下例举imp常用用法. 1. 获取帮助 imp help=y 2. 导入一个完整数据库 imp system/manager file=bible_db log=dible_db full=y ignore=y 3. 导入一个或一组指定用户所属的全部表.索引和其他对象

ORACLE PL/SQL编程详解

ORACLE PL/SQL编程详解 编程详解 SQL语言只是访问.操作数据库的语言,并不是一种具有流程控制的程序设计语言,而只有程序设计语言才能用于应用软件的开发.PL /SQL是一种高级数据库程序设计语言,该语言专门用于在各种环境下对ORACLE数据库进行访问.由于该语言集成于数据库服务器中,所以PL/SQL代码可以对数据进行快速高效的处理.除此之外,可以在ORACLE数据库的某些客户端工具中,使用PL/SQL语言也是该语言的一个特点.本章的主要内容是讨论引入PL/SQL语言的必要性和该语言的

[顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功)

原文:[顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功) [顶]ORACLE PL/SQL编程详解之二: PL/SQL块结构和组成元素(为山九仞,岂一日之功) 继上四篇:ORACLE PL/SQL编程之八:把触发器说透                ORACLE PL/SQL编程之六:把过程与函数说透(穷追猛打,把根儿都拔起!)                [推荐]ORACLE PL/SQL编程之四:把游标说透(不怕做不到,只怕想不到) [推荐]

【强烈强烈推荐】《ORACLE PL/SQL编程详解》全原创(共八篇)--系列文章导航

原文:[强烈强烈推荐]<ORACLE PL/SQL编程详解>全原创(共八篇)--系列文章导航 <ORACLE PL/SQL编程详解> 系列文章目录导航 ——通过知识共享树立个人品牌. 本是成书的,但后来做其他事了,就无偿的贡献出来,被读者夸其目前为止最“实在.经典”的写ORACLE PL/SQL编程的文章-! 觉得对你有帮助,请留言与猛点推荐,谢谢. [推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下) 本篇主要内容如下:第一章 PL/S

[推荐]ORACLE PL/SQL编程详解之三:PL/SQL流程控制语句(不给规则,不成方圆)

原文:[推荐]ORACLE PL/SQL编程详解之三:PL/SQL流程控制语句(不给规则,不成方圆) [推荐]ORACLE PL/SQL编程详解之三: PL/SQL流程控制语句(不给规则,不成方圆) ——通过知识共享树立个人品牌. 继上五篇: [顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功) [推荐]ORACLE PL/SQL编程之四:把游标说透(不怕做不到,只怕想不到) [推荐]ORACLE PL/SQL编程之五:异常错误处理(知已知彼.百战不

[推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下)

原文:[推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下) [推荐]ORACLE PL/SQL编程详解之一: PL/SQL 程序设计简介(千里之行,始于足下) ——通过知识共享树立个人品牌. 继上六篇: [顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功) [推荐]ORACLE PL/SQL编程详解之三:PL/SQL流程控制语句(不给规则,不成方圆) [推荐]ORACLE PL/SQL编程之四:把游标说透(