zoukankan      html  css  js  c++  java
  • 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;
     
  • 相关阅读:
    二分图的部分关系
    二分图的部分关系
    日常训练赛 Problem C – Complete Naebbirac’s sequence
    日常训练赛 Problem C – Complete Naebbirac’s sequence
    J
    J
    Python strip()方法
    Python startswith()方法
    Python splitlines()方法
    Python split()方法
  • 原文地址:https://www.cnblogs.com/JIKes/p/12367369.html
Copyright © 2011-2022 走看看