如何找出消耗cup的进程信息和执行的语句

王朝other·作者佚名  2006-11-24
宽屏版  字体: |||超大  

要找出最耗资源的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.

SIDSERIAL# 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

oracle@cs_db02:/arch1/lunar/tools >

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有