查找Oracle高消耗语句的方法

  次阅读 作者:智能小宝 来源:互联网 2016-01-26 11:03 我要评论(0)

这篇文章主要介绍了查找Oracle高消耗语句的方法,需要的朋友可以参考下

在运行下面的脚本之前需要先用生成AWR报告的SQL(程序脚本一般保存在$ORACLE_HOME下的rdbms/admin中,名称为 awrrpt.sql,需要输入生成AWR报告的天数范围)找到开始和结束的snapshot编号:begin_snap和end_snap。

代码如下:

<span style="font-size:18px;">set line 1000

set linesize 200

set pagesize 2000

set long 999999

set echo on

set markup html on

select res.*

from (select to_char(d.end_interval_time,'yyyy-mm-dd'),

a.PARSING_SCHEMA_NAME,

c.MODULE,

a.sql_id,

a.execs as 执行次数,

ROUND(a.cpu_times / a.execs, 2) as 单次执行时间,

a.cpu_times as cpu消耗时间,

ROUND(a.cpu_times / b.sum_time * 100, 2) as 消耗cpu百分比,

a.buffer_gets as 逻辑读,

ROUND(a.buffer_gets / b.sum_buffer * 100, 2) as 逻辑读百分比,

a.disk_read as 物理读,

ROUND(a.disk_read / b.sum_disk * 100, 2) as 物理读百分比,

c.sql_fulltext

from (select PARSING_SCHEMA_NAME,

sql_id,

sum(EXECUTIONS_DELTA) AS execs,

round(sum(CPU_TIME_DELTA) / 1000000, 2) AS cpu_times,

round(sum(ELAPSED_TIME_DELTA) / 1000000, 2) AS elapsed_time,

sum(BUFFER_GETS_DELTA) AS buffer_gets,

sum(DISK_READS_DELTA) AS disk_read

from sys.WRH$_SQLSTAT wr, gv$instance i

where SNAP_ID <= &end_snap

and snap_id >= &begin_snap

and wr.INSTANCE_NUMBER = i.INSTANCE_NUMBER

and i.instance_number = &instance_number

group by PARSING_SCHEMA_NAME, wr.INSTANCE_NUMBER, sql_id) a,

(SELECT round(SUM(CPU_TIME_DELTA) / 1000000, 2) sum_time,

SUM(BUFFER_GETS_DELTA) sum_buffer,

sum(DISK_READS_DELTA) sum_disk

FROM sys.WRH$_SQLSTAT wr, gv$instance i

where SNAP_ID <= &end_snap

and snap_id >= &begin_snap

and wr.INSTANCE_NUMBER = i.INSTANCE_NUMBER

and i.instance_number = &instance_number) b,

v$sqlarea c,

dba_hist_snapshot d

where a.execs > 0

and a.sql_id = c.sql_id

and a.PARSING_SCHEMA_NAME <> 'SYS'

and d.snap_id = &end_snap

order by cpu消耗时间 desc) res

where rownum < 41;

exit</span>

将脚本输出内容保存到记事本txt中,并将记事本的后缀名更改为.html,这样就可以输出以下的网页内容

本站文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 无人驾驶汽车如何改变城市生活?听听他们怎么说

    无人驾驶汽车如何改变城市生活?听听他们怎么说

  • 未来两年人工智能要怎么走?看这篇就够了

    未来两年人工智能要怎么走?看这篇就够了

  • 韩春雨称已能重复实验结果 近期将有消息公布

    韩春雨称已能重复实验结果 近期将有消息公布

  • 英国研发“杀生”机器人 通过生命体获取能量

    英国研发“杀生”机器人 通过生命体获取能量

网友点评网友点评
阅读推荐阅读推荐

据国外媒体报道,在过去两年内,聊天机器人(chatbot)、人工智能以及机器学习的研发和采用取得了巨大进展。许多初创公司正利用人工智能和...

霍金 视觉中国 图 英国著名物理学家霍金(Stephen Hawking)再次就人工智能(AI)发声,他认为:对于人类来说,强大AI的出现可能是最美妙的...

文|郑娟娟 今年,人工智能(AI) 60岁了。在AI60岁的时候,笔者想要介绍一下AI100,一个刚刚2岁的研究项目,但它的预设寿命是100年,甚至更长...

AlphaGo与李世石的人机大战,为大众迅速普及了人工智能的概念。 但对谷歌而言,除了下围棋,现在的人工智能进展到哪一步了?未来,人工智能...