Oracle数据库中跟踪sql语句介绍
来源:优易学  2011-9-11 13:52:24   【优易学:中国教育考试门户网】   资料下载   IT书店

  如果应用程序的代码无法修改或者是不想去修改,则可以在其他会话中打开对特定会话的跟踪,方法如下:
  1)sys.dbms_system.set_bool_param_in_session(:sid, :serial,’timed_statistics’, true);
  2)sys.dbms_system.set_int_param_in_session( :sid, :serial,’max_dump_file_size’, 2147483647);
  打开和关闭跟踪的第一种方法(oracle推荐):
  3.1)sys.dbms_support.start_trace_in_session(:sid, :serial,waits=>true, binds=>false);
  /* 在此期间运行要跟踪的应用程序*/
  4.1)sys.dbms_support.stop_trace_in_session(:sid, :serial);
  打开和关闭跟踪的第二种方法:
  3.2)sys.dbms_system.set_ev(:sid, :serial, 10046, 8, ’’);
  /*在此期间运行要跟踪的应用程序*/
  3.2)sys.dbms_system.set_ev(:sid, :serial, 10046, 0, ’’);
  以上语句中的:sid和:serial分别代表所要跟踪的会话的ID和序列号,这些信息可以从V$SESSION视图的SID和SERIAL#列获得。打开关闭跟踪中第一种方法的好处是你不用自己写10046这个事件号,这样可以减少错误,但是dbms_support程序包在你的数据库中可能会不存在,这样就只有用第二种方法了。
  到现在为止,我们已经生成了所需要的跟踪文件,然后我们需要找到该文件来进行分析。跟踪文件的存放位置只有两种可能,Oracle参数USER_DUMP_DEST 或者BACKGROUND_DUMP_DEST指定的目录;文件名称根据不同的平台会有所不同,但是在文件名中都会包含会话所对应的操作系统进程(线程)号,也就是V$PROCESS的SPID列(V$PROCESS.SPID) ,该信息可以通过 v$process.addr和v$session.paddr做表连接查询得到。例如:select spid from v$process p,v$session s where p.addr=s.paddr and s.sid=:sid and s.serial#=:serial.
  青年人网编辑只对Oracle在使用专用服务器进程(Dedicated Server)模式做了总结,至于的共享服务器(Shared Server)模式和在应用级使用连接池的情况下,收集sql跟踪信息的方法会比较复杂,希望有相关经验的总结。

上一页  [1] [2] 

责任编辑:小草

文章搜索:
 相关文章
热点资讯
热门课程培训