码迷,mamicode.com
首页 > 数据库 > 详细

oracle造成系统CPU过高的检查sql

时间:2017-09-25 19:00:42      阅读:200      评论:0      收藏:0      [点我收藏+]

标签:gre   asc   where   ddr   order by   语句   rom   csharp   logs   

1、 根据占用CPU高的进程号来查询这个进程执行的SQL语句:

CPU过高的进程号:

#首先找到CPU过高的进程号
# top -bn1 是静态找到占用最高的进程
[root@localhost ~]# top -bn1 | awk ‘{print $1}‘ | grep -A2 PID

 

SQL语句:

SELECT sql_text
FROM V$sqltext a
WHERE (a.hash_value, a.address)
IN (SELECT DECODE(sql_hash_value, 0 , prev_hash_value, sql_hash_value),
DECODE(sql_hash_value, 0 ,prev_sql_addr, sql_address)
FROM v$session b
WHERE b.paddr = (SELECT addr FROM v$process c WHERE c.spid = ‘&pid‘))
ORDER BY piece ASC;

#######
ex:
SELECT sql_text 
FROM v$sqltext a 
WHERE (a.hash_value, a.address) 
IN (SELECT DECODE(sql_hash_value, 0, prev_hash_value, sql_hash_value), 
DECODE(sql_hash_value, 0, prev_sql_addr, sql_address) 
FROM v$session b 
WHERE b.paddr = (SELECT addr FROM v$process c WHERE c.spid = ‘31968‘)) 
ORDER BY piece ASC;

 

oracle造成系统CPU过高的检查sql

标签:gre   asc   where   ddr   order by   语句   rom   csharp   logs   

原文地址:http://www.cnblogs.com/frankielf0921/p/7593066.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!