ORACLE CPU过高的sql查询

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

CPU过高的进程号:

#首先找到CPU过高的进程号
# top -bn1 是静态找到占用最高的进程
 
[root@localhost ~]# top -bn1 | awk  '{print $1}'  | grep -A2 PID
 
命令详解:  
  top:top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况
  -bn1: 显示所有的进程信息  (top -bn 1    显示所有进程信息,top -n 1 只显示一屏信息,供管道调用  )
   awk  '{print $1}':
    awk是用来提取列的主要工具;
    {print $1}就是将某一行(一条记录)中以空格为分割符的第一个字段打印出来
 grep -A2 PID : (查看前二行的进程号) -A: 显示匹配行及前面多少行, 如: -A3, 则表示显示匹配行及前3行
 
 
 

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 =  '3515' ))
ORDER  BY  piece  ASC ;
 

猜你喜欢

转载自www.cnblogs.com/JIKes/p/12367369.html