LogMiner Tool
dbms_logmnr是oracle在oracle8i所提供的新package。它主要用于分析log file文件(包括online redo log file,archived log file),將log file中的信息轉存到v$logmnr_contents中,從而獲取對oracle數據庫操作的歷史信息。它不僅可以分析oracle8i的log file,也可以分析oracle8的log file。信息主要包括在你分析的時間限制內數據庫數據作了些什么變更,執行了哪些語句。
2、使用方法
1)打開;init.ora文件,加入utl_file_dir=d:\oracle(注:改為自己的路徑,是logminer使用文件的默認路徑),然后應用新的設置打開oracle數據庫。
2)執行SQL>;。 execute dbms_logmnr_d.build('shwdict.ora','D:\oracle'); ,(注:將生成d:\oracle\shwdict.ora文件,此文件可以以后重復使用,但不能同時用于幾個logmnr)用于生成數據字典;如果沒有 dbms_logmnr_d包,需手工執行@d:\oracle\ora8\rdbms\admin\dbmslmd.sql;如果執行過程中報下標越界錯誤,則需要打開@d:\oracle\ora8\rdbms\admin\dbmslmd.sql文件,將其中的TYPE col_desc_array IS VARRAY(513) OF col_description的513加大,我是改成了1513,保存文件重新執行@d:\oracle\ora8\rdbms\admin \dbmslmd.sql;(注:都要以sysdba身份登陸執行)。
3)將要分析的日志文件加入要分析的log list中,察看有哪些日志文件可以用select * from v$logfile;查詢已經加入那些可以用select * from v$logmnr_logs(注:查詢必須在同一個會話中查詢,單獨開查詢將查不到)語句如下:
?execute dbms_logmnr.add_logfile('d:\oracle\oradata\shw\redo01_1.log',dbms_logmnr.new);execute dbms_logmnr.add_logfile('d:\ORACLE\ORADATA\ORA\REDO02_1.LOG',dbms_logmnr.addfile);execute dbms_logmnr.add_logfile('d:\ORACLE\ORADATA\ORA\REDO03_1.LOG',dbms_logmnr.addfile);
如果需要從分析列表里去掉一個文件用
('d:\ORACLE\ORADATA\ORA\REDO03_1.LOG',dbms_logmnr.removefile);
4)更改會話時間表達方式(注一定要在本會話下修改,我開始發生錯誤就是因為在別的會話里修改的,如果允許,可以將數據庫默認的時間表達方式修改掉)會話內修改為alter session set nls_date_format='yyyy-mm-dd hh24:mi:ss'; 系統設置在注冊表。
5)查詢分析的日志文件包含的scn范圍和日期范圍。
select low_time,high_time,low_scn,next_scn from v$logmnr_logs;
會列出你加入的日志文件的以上信息。
?6)執行分析:
dbms_logmnr.start_logmnr(dictfilename=> 'd:\oracle\shwdict.ora',startscn=>xxxxxx,endscn=>xxxxx,starttime => to_date('20030501 12:15:00','yyyymmdd hh24:mi:ss'), endtime =>to_date('20030501 15:40:30','yyyymmdd hh24:mi:ss'));
要注意scn范圍和日期格式,格式要與你修改的一樣。
?7)查詢
Select SCN,timestamp, session# session_num, sql_redoFrom V$LOGMNR_CONTENTS Order by 1
-------------------------------------------------------------------------
MyScript for experience
EXECUTE dbms_logmnr_d.build('shwdict.ora','C:\oracle\product\10.2.0\oradata\MyTest');
execute dbms_logmnr.add_logfile('C:\oracle\product\10.2.0\db_2\database\archive\ARC00020_0656442411.001',dbms_logmnr.new);
execute dbms_logmnr.add_logfile('C:\oracle\product\10.2.0\oradata\MyTest\REDO02.LOG',dbms_logmnr.addfile);
execute dbms_logmnr.add_logfile('C:\oracle\product\10.2.0\oradata\MyTest\REDO03.LOG',dbms_logmnr.addfile);
--execute dbms_logmnr.add_logfile('C:\oracle\product\10.2.0\oradata\MyTest\REDO03.LOG',dbms_logmnr.removefile);
alter session set nls_date_format='yyyy-mm-dd hh24:mi:ss';
select low_time,high_time,low_scn,next_scn from v$logmnr_logs;
exec dbms_logmnr.start_logmnr(DictFileName=>'C:\oracle\product\10.2.0\oradata\MyTest\shwdict.ora');
exec dbms_logmnr.start_logmnr(DictFileName=>'C:\oracle\product\10.2.0\oradata\MyTest\shwdict.ora',startscn=>774536,endscn=>788085);
set colsep '|'?????????????? --設置|為列分隔符
set trimspool on
set linesize 120
set pagesize 2000?????????
set newpage 1
set heading off???????????
set term off
set num 18?????????????????
set feedback off???????????
spool 'c:\tmp.txt'
Select SCN,timestamp, session# session_num, sql_redo From V$LOGMNR_CONTENTS Order by 1;
--SELECT SCN,timestamp, session# session_num, sql_redo FROM v$logmnr_contents where scn between 774535 and 788085 and table_name='DM_DJ_SWRY';
spool off
execdbms_logmnr.end_logmnr;
轉載于:https://www.cnblogs.com/yifan268/archive/2008/07/06/1237048.html
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的LogMiner Tool的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: solidworks怎么画抽纸盒? sw
- 下一篇: Win10开机蓝屏提示CLASSPNP.