程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle數據庫基礎 >> 查看Oracle日志的實現方法

查看Oracle日志的實現方法

編輯:Oracle數據庫基礎

查看Oracle日志有多種的方法,下面就教您如何使用dbms_logmnr實現查看Oracle日志信息的方法,如果您遇到過類似的問題,不妨一看。

1:介紹: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)將要分析的Oracle日志文件加入要分析的log list中,察看有哪些Oracle日志文件可以用

select * from v$logfile;

查詢已經加入那些可以用

select * from v$logmnr_logs(注:查詢必須在同一個會話中查詢,單獨開查詢將查不到)

語句如下:

  1. execute dbms_logmnr.add_logfile('d:\Oracle\oradata\shw\redo01_1.log',dbms_logmnr.new);  
  2.  
  3. execute dbms_logmnr.add_logfile('d:\Oracle\ORADATA\ORA\REDO02_1.LOG',dbms_logmnr.addfile);  
  4.  
  5. execute dbms_logmnr.add_logfile('d:\Oracle\ORADATA\ORA\REDO03_1.LOG',dbms_logmnr.addfile);  

如果需要從分析列表裡去掉一個文件用

  1. ('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范圍和日期范圍。

  1. select low_time,high_time,low_scn,next_scn from v$logmnr_logs; 

會列出你加入的日志文件的以上信息。

6)執行分析:

  1. dbms_logmnr.start_logmnr(  
  2. 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:查詢

  1. Select SCN,timestamp, session# session_num, sql_redo  
  2. From V$LOGMNR_CONTENTS  
  3. Order by 1  

具體要查詢什麼內容可以自己修改。
 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved