oracle sql跟蹤方法:
1、sql_trace
打開跟蹤:alter session set sql_trace=true;
為跟蹤文件做標記:alter session set tracefile_identifier='look_for_me';
停止跟蹤:alter session set sql_trace=false;
最后生成的跟蹤文件可以采用tkprof工具生成來查看。
2、10046跟蹤代碼
跟蹤界別介紹:
Level 0 停用SQL跟蹤,相當於SQL_TRACE=FALSE
Level 1 標准SQL跟蹤,相當於SQL_TRACE=TRUE
Level 4 在level 1的基礎上增加綁定變量的信息
Level 8 在level 1的基礎上增加等待事件的信息
Level 12 在level 1的基礎上增加綁定變量和等待事件的信息
打開跟蹤:
GRANT ALTER SESSION TO lttfm; --必須具有alter session權限
alter session set events '10046 trace name context forever,level 12';--當前用戶設置
或者在init.ora文件中插入下面的行:event = 10046 trace name context forever,level 12;--為全局設置
關閉跟蹤:
alter session set events '10046 trace name context off';--關閉用戶跟蹤
注:sql_trace和10046設置代碼跟蹤只能針對本會話或者系統級進行會話跟蹤,具體設置某個非本會話的跟蹤需要采用oradebug或者
dbms_system.set_ev或者dbms_monitor.session_trace_enable。
3、使用oradebug
--用如下語句找出要跟蹤的spid
select * from v$session a where audsid = userenv('sessionid'); --查詢當前的sessionid
select s.USERNAME,
s.OSUSER,
s.SID,
s.PADDR,
s.PROCESS,
p.spid os_process_id,
p.pid oracle_process_id
from v$session s, v$process p
where s.paddr = p.addr
and s.username = upper('LTWEBGIS')
and s.SID = 145;
--設置跟蹤進程id。
SQL> connect / as sysdba
SQL> oradebug setospid 5672;該語句為跟蹤其他會話(5672為v$process的spid),
若跟蹤本會話,執行 oradebug setmypid。
或
SQL> connect / as sysdba
SQL> oradebug setorapid 15 --輸入的15為v$process的pid
--設置跟蹤文件大小無限制
SQL> oradebug unlimit;
--設置跟蹤,級別8
SQL> oradebug event 10046 trace name context forever,level 8;
已處理的語句
--關閉跟蹤
SQL> oradebug event 10046 trace name context off;
執行該語句(SQL> oradebug setospid 5672;)時,提示“ORA-01031: 權限不足”,
原因:oradebug是sysdba的命令(一般用戶執行提示權限不足),而且是sqlplus特有的命令,不能在plsql工具中執行(否則提示無效sql)。
可以用oradebug help命令查看oradebug工具說明。
4、dbms_system(必須用sys用戶執行)
exec dbms_system.set_ev(si => 159,se => 254,ev => 10046,le =>8 ,nm => '');--會話id等參數必須設置正確,否則trace無法生成
生成后可用sql語句查看trace文件位置。
--停止跟蹤
exec dbms_system.set_ev(si => 159,se => 254,ev => 10046,le =>0 ,nm => '');
5、dbms_monitor
exec dbms_monitor.session_trace_enable(session_id => 136,serial_num => 4,waits => true,binds => true);
exec dbms_monitor.session_trace_disable(session_id => 136,serial_num => 4);
如果不設置session_id或者設置為null,則跟蹤當前會話
6、dbms_support
exec dbms_support.start_trace_in_session(sid => 1234,serial# => 56789,waits => true,binds => true);
exec dbms_support.stop_trace_in_session(sid => 1234,serial# => 56789);
dbms_support默認情況下,系統不安裝這個包。如果需要使用的話,需進行單獨設置。在$ORACLE_HOME/rdbms/admin/目錄下應該存在
dbmssupp.sql,prvtsupp.plb這兩個文件,執行這兩個文件后才可使用,如果別的用戶要使用,需要進行相應的授權,並創建同義詞。
注:3,4,5,6這幾種跟蹤方法都是在sys的用戶下才能執行,可對任意會話進行跟蹤。
獲取跟蹤文件:
1)oradebug獲取跟蹤文件
--使用oradebug獲取本會話跟蹤文件位置
SQL> oradebug setmypid
SQL> oradebug tracefile_name
--獲取任意會話跟蹤文件位置
SQL> oradebug setospid 5392
已處理的語句
SQL> oradebug tracefile_name
d:\oracle\product\10.2.0\admin\fgisdb\udump\fgisdb_ora_5600.trc
2)sql獲取跟蹤文件
--sql查看當前session跟蹤文件位置
SELECT d.value || '\' || lower(rtrim(i.instance_name, chr(0))) || '_ora_' ||
p.spid || '.trc' trace_file_name
FROM (SELECT p.spid
FROM v$mystat m, v$session s, v$process p
WHERE m.statistic# = 1
AND s.sid = m.sid
AND p.addr = s.paddr) p,
(SELECT instance_name FROM v$instance) i,
(SELECT VALUE FROM v$parameter WHERE NAME = 'user_dump_dest') d;
--以下sql為查詢輸入的spid的會話跟蹤文件
select d.value || '\' || lower(rtrim(i.instance_name, chr(0))) || '_ora_' ||
&spid || '.trc' trace_file_name
from (SELECT instance_name FROM v$instance) i,
(select value from v$parameter where name = 'user_dump_dest') d;
查看跟蹤級別
1)查看當前session的跟蹤級別(必須在sys用戶下執行)
declare
event_level number;
begin
dbms_system.read_ev(10046,event_level);
dbms_output.put_line(to_char(event_level));
end;
2)執行如下語句查看跟蹤事件的跟蹤級別
SQL> oradebug setospid spid --先指定要查看跟蹤級別的spid
SQL> oradebug eventdump session
10046 trace name CONTEXT level 8, forever
注:如果開啟了跟蹤會話,但之后數據庫關閉,那么跟蹤自動關閉。