当前位置:首页 > 如何找出最耗资源的sql

如何找出最耗资源的sql

点击次数:1694  更新日期:2011-12-13
要找出最耗资源的sql,我们可以首先使用top等工具,找到最好资源的进程(记住进程号),例如,操作系统进程号为1217,然后根据这个进程号(v$process.spid)在v$process中找到进程地址(v$process.addr),然后根据这个地址在v$session中找到相应的sid(v$session.sid),然后根据这个sid找到相应的hash alue(v$session. sql_hash_value),然后根据这个hash alue在v$sqltext,$sql,v$sqlarea等视图中找到对应的sql语句(sql_text)。
 
例如:
oracle@cs_db02:/arch1/lunar/tools > whoistopsql.sh 6799
connected.
       sid    serial# username                       osuser                         machine                        program    process      to_char(logon_time,
---------- ---------- ------------------------------ ------------------------------ ------------------------------ ---------------------------------------- ------------ -------------------
       483       1224 portal                         www16                          bj_wap03                       jdbc thin client 2004/09/22 02:21:03


sql_text
----------------------------------------------------------------
select * from spinfo where spid = :1