学院栏目导航: 业界新闻 网页设计 程序设计 数据库类 网络技术 操作系统 图形图像 办公软件 考试认证 多媒体类 硬件资讯

您的位置:首页-> 资讯中心-> 软件学院-> 数据库-> SQLServer-> 如何找出消耗cup的进程信息和执行的语句

→ SQLServer

  SQLServer
MySQL
Access
Sybase
Oracle
IBMDB2
PowerBuilder
其他数据库

广告专栏


本类阅读TOP10
·TOPN 子句与SET ROWCOUNTN 之对比
·讨论: SELECT TOP N 问题
·SQL Server 2000的安全配置
·Sql联合查询
·调整重心-从IIS到SQL Server数据库安全
·数据库升迁从sqlserver6.5到sqlserver2000
·SELECT查询的应用(三)
·SQL Server补丁安装常见问题
·MySQL中如何实现Top N及M至N段的记录查询?
·浅谈数据库的攻击

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

来源:未知 发表时间:2004-11-29 【ovo.com.cn

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

oracle@cs_db02:/arch1/lunar/tools >



※相关文章:

※相关软件: