如何定位占用oracle数据库cpu过高的sql

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何定位占用oracle数据库cpu过高的sql相关的知识,希望对你有一定的参考价值。

ORACLE查询当前执行效率低的sql
  --CPU高的SQL
  select sql_text from v$sql order by cpu_time desc
  --逻辑读多的SQL:
  select * from (select buffer_gets, sql_text
  from v$sqlarea
  where buffer_gets > 500000
  order by buffer_gets desc) where rownum<=30;
  --执行次数多的SQL :
  select sql_text,executions from
  (select sql_text,executions from v$sqlarea order by executions desc)
  where rownum<81;
  --读硬盘多的SQL :
  select sql_text,disk_reads from
  (select sql_text,disk_reads from v$sqlarea order by disk_reads desc)
  where rownum<21;
参考技术A 一般通过awr报告,可以找到一段时间内占用cpu前十的sql

Oracle查询语句导致CPU使用率过高问题处理

解决此问题的关键在于如何找到造成CPU使用率过高的SQL语句。步骤如下:

1、使用Process Explorer工具查看到Oracle进程,双击Oracle进程,在弹出的属性窗口的Threads选项卡中查看占用CPU较高的线程号(TID)。

2、在PL/SQL工具中执行以下SQL语句:

--根据sql_id获取对应的Sql语句(sql_text,sql_fulltext)
select *
from v$sqlarea
where sql_id in
(
  --根据addr获取sql_id
  select sql_id
  from v$session
  where paddr in
    --根据线号获取process的addr
    (select addr from v$process where spid in (‘&spid:线程号‘))
);

3、在上述SQL查询语句的结果中 “sql_text"、"sql_fulltext"两列就是要找的SQL语句。

4、根据不同的SQL语句进行调优即可。

 

以上是关于如何定位占用oracle数据库cpu过高的sql的主要内容,如果未能解决你的问题,请参考以下文章

[转]定位占用oracle数据库cpu过高的sql

Oracle 占用cpu过高的处理办法

Java如何定位占用CPU比较高的问题

如何查询占CPU高的oracle进程

Linux 线程占用CPU过高定位分析

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