最近书看的多,疏于操作了,今天练习使用了一下sql_trace,还是发现了问题
1、首先是如何找到生的的trace文件,是存在user_dump_dest目录下,用show parameter dump或者user_dump_dest能看到目录路径, /u01/diag/rdbms/zero/zero/trace/,然后是怎样找到刚刚生成的文件。
2、去eygle的网站搜了一下sql_trace,对它有个挺详细的解释,对于刚生成的跟踪文件位置可以用下面这个查询得到(不明白这么复杂的查询是怎么写出来的)
SQL> select
2 d.value||'/'||lower(rtrim(i.instance, chr(0))) ||'_ora_'||p.spid||'.trc' trace_file_name
3 from
4 ( select p.spid
5 from sys.v$mystat m,sys.v$session s,sys.v$process p
6 where m.statistic# = 1 and s.sid = m.sid and p.addr = s.paddr) p,
7 ( select t.instance from sys.v$thread t,sys.v$parameter v
8 where v.name = 'thread' and (v.value = 0 or t.thread# = to_number(v.value))) i,
9 ( select value from sys.v$parameter where name = 'user_dump_dest') d
10 /
3、直接复制粘贴,确实能够输出一个跟踪文件的路径,但很奇怪的是在trace目录下找不到这个文件,但有另外一个文件名差几号的文件是所生成的trace文件,直觉是和可能和系统时间有关系,我用的vmware,linux时间比外面windows时间快两个小时,于是把时间改回来,重新查询,问题解决了!很奇怪,不知道还有什么深层的原因,在这留作疑问,待研究、、、
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/17016200/viewspace-563237/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/17016200/viewspace-563237/