如何定位占用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的主要内容,如果未能解决你的问题,请参考以下文章