sql_trace和autotrace和explain plan都是Oracle提供的用于进行SQL跟踪的手段,是强有力的辅助诊断工具!
第一:autotrace必须要在sql*plus下使用,其使用语法如下:
1、关闭autotrace功能:
set autotrace off;
set autotrace off;
2、产生结果集和解释计划并列出统计:
set autotrace on;
set autotrace on;
3、显示结果集和解释计划不显示统计:
set autotrace on explain;
set autotrace on explain;
4、显示解释计划和统计,尽管执行该语句但您将看不到结果集:
set autotrace trace only;
set autotrace trace only;
5、只显示统计;
set autotrace traceonly statistics;
set autotrace traceonly statistics;
第二:sql_trace在使用方法如下:
1、要明确跟踪的session
在全局中使用sql_trace,可以通过参数文件(pfile/spfile)中指定:sql_trace=true,
或者使用命令:alter system set sql_trace=true scope=spfile
此时所有进程都将跟踪sql的执行信息,导致性能受到影响,生产系统慎用!
在全局中使用sql_trace,可以通过参数文件(pfile/spfile)中指定:sql_trace=true,
或者使用命令:alter system set sql_trace=true scope=spfile
此时所有进程都将跟踪sql的执行信息,导致性能受到影响,生产系统慎用!
2、在当前进程下启动可以用一下命令:
alter session set sql_trace=true;
alter session set sql_trace=true;
3、如果想要跟踪其它进程,可以使用一下语句:
dbms_system.set_sql_trace_in_session(sid,serial#,sql_trace);
dbms_system.set_sql_trace_in_session(sid,serial#,sql_trace);
可以通过select sid,serial#,sql_trace from v$session where username is not null来查看这三个参数;
然后设置跟踪:
exec dbms_system.set_sql_trace_in_session(63,31,true);
exec dbms_system.set_sql_trace_in_session(63,31,true);
跟踪一段时间后
停止跟踪:
exec dbms_system.set_sql_trace_in_session(63,31,false);
exec dbms_system.set_sql_trace_in_session(63,31,false);
用show parameter user_dump_dest 查看trace文件的目录;
用以下语句查找生成的文件:
select
d.value||'/'||lower(rtrim(i.instance, 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 t.instance from v$thread t,v$parameter v
where v.name = 'thread' and (v.value = 0 or t.thread# = to_number(v.value))) i,
(select value from v$parameter where name = 'user_dump_dest') d
然后用tkprof 上述的路径\最新生成的trc文件 f:\sql_trace.txt
select
d.value||'/'||lower(rtrim(i.instance, 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 t.instance from v$thread t,v$parameter v
where v.name = 'thread' and (v.value = 0 or t.thread# = to_number(v.value))) i,
(select value from v$parameter where name = 'user_dump_dest') d
然后用tkprof 上述的路径\最新生成的trc文件 f:\sql_trace.txt
最后即可在f:\下查看新生成的sql_trace.txt文件了!
第三:用explain plan for
首先,在SQL*PLUS 下:explain plan for select语句
然后通过select * from table(dbms_xplan.display())语句查看执行计划;
点评:比较常用的是autotrace和explain plan for,但是tkprof比较准确和通俗,能生成报表分析!
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/26977915/viewspace-734015/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/26977915/viewspace-734015/