在缺乏的可视化工具来监控数据库性能的情形下,常用的脚本就派上用场了,下面提供几个关于Oracle性能相关的脚本供大家参考。以下脚本均在Oracle 10g测试通过,Oracle 11g可能要做相应调整。

1、寻找最多BUFFER_GETS开销的SQL 语句

  1. --filename: top_sql_by_buffer_gets.sql
  2. --Identify heavy SQL (Get the SQL with heavy BUFFER_GETS)
  3. SET LINESIZE 190
  4. COL sql_text FORMAT a100 WRAP
  5. SET PAGESIZE 100
  6. SELECT *
  7. FROM (  SELECT sql_text,
  8. sql_id,
  9. executions,
  10. disk_reads,
  11. buffer_gets
  12. FROM v$sqlarea
  13. WHERE DECODE (executions, 0, buffer_gets, buffer_gets / executions) >
  14. (SELECT AVG (DECODE (executions, 0, buffer_gets, buffer_gets / executions))
  15. + STDDEV (DECODE (executions, 0, buffer_gets, buffer_gets / executions))
  16. FROM v$sqlarea)
  17. AND parsing_user_id != 3D
  18. ORDER BY 5 DESC) x  /*更正@20140613,原来为order by 4,感谢网友lmalds指正*/
  19. WHERE ROWNUM <= 10;

2、寻找最多DISK_READS开销的SQL 语句

  1. --filename:top_sql_disk_reads.sql
  2. --Identify heavy SQL (Get the SQL with heavy DISK_READS)
  3. SET LINESIZE 190
  4. COL sql_text FORMAT a100 WRAP
  5. SET PAGESIZE 100
  6. SELECT *
  7. FROM (  SELECT sql_text,
  8. sql_id,
  9. executions,
  10. disk_reads,
  11. buffer_gets
  12. FROM v$sqlarea
  13. WHERE DECODE (executions, 0, disk_reads, disk_reads / executions) >
  14. (SELECT AVG (DECODE (executions, 0, disk_reads, disk_reads / executions))
  15. + STDDEV (DECODE (executions, 0, disk_reads, disk_reads / executions))
  16. FROM v$sqlarea)
  17. AND parsing_user_id != 3D
  18. ORDER BY 4 DESC) x  /* 更正@20140613,原来为order by 3,谢谢网友lmalds指正*/
  19. WHERE ROWNUM <= 10;

3、寻找最近30分钟导致资源过高开销的事件

  1. --filename:top_event_in_30_min.sql
  2. --Last 30 minutes result those resources that are in high demand on your system.
  3. SET LINESIZE 180
  4. COL event FORMAT a60
  5. COL total_wait_time FORMAT 999999999999999999
  6. SELECT active_session_history.event,
  7. SUM (
  8. active_session_history.wait_time
  9. + active_session_history.time_waited)
  10. total_wait_time
  11. FROM v$active_session_history active_session_history
  12. WHERE active_session_history.sample_time BETWEEN SYSDATE - 60 / 2880
  13. AND SYSDATE
  14. AND active_session_history.event IS NOT NULL
  15. GROUP BY active_session_history.event
  16. ORDER BY 2 DESC;

4、查找最近30分钟内等待最多的用户

  1. --filename:top_wait_by_user.sql
  2. --What user is waiting the most?
  3. SET LINESIZE 180
  4. COL event FORMAT a60
  5. COL total_wait_time FORMAT 999999999999999999
  6. SELECT ss.sid,
  7. NVL (ss.username, 'oracle') AS username,
  8. SUM (ash.wait_time + ash.time_waited) total_wait_time
  9. FROM v$active_session_history ash, v$session ss
  10. WHERE ash.sample_time BETWEEN SYSDATE - 60 / 2880 AND SYSDATE AND ash.session_id = ss.sid
  11. GROUP BY ss.sid, ss.username
  12. ORDER BY 3 DESC;

5、查找30分钟消耗最多资源的SQL语句

  1. --filename:top_sql_by_wait.sql
  2. -- What SQL is currently using the most resources?
  3. SET LINESIZE 180
  4. COL sql_text FORMAT a90 WRAP
  5. COL username FORMAT a20 WRAP
  6. SET PAGESIZE 200
  7. SELECT *
  8. FROM (  SELECT sqlarea.sql_text,
  9. dba_users.username,
  10. sqlarea.sql_id,
  11. SUM (active_session_history.wait_time + active_session_history.time_waited)
  12. total_wait_time
  13. FROM v$active_session_history active_session_history, v$sqlarea sqlarea, dba_users
  14. WHERE     active_session_history.sample_time BETWEEN SYSDATE - 60 / 2880 AND SYSDATE
  15. AND active_session_history.sql_id = sqlarea.sql_id
  16. AND active_session_history.user_id = dba_users.user_id
  17. GROUP BY active_session_history.user_id,
  18. sqlarea.sql_text,
  19. sqlarea.sql_id,
  20. dba_users.username
  21. ORDER BY 4 DESC) x
  22. WHERE ROWNUM <= 11;

6、等待最多的对象

  1. --filename:top_object_by_wait.sql
  2. --What object is currently causing the highest resource waits?
  3. SET LINESIZE 180
  4. COLUMN OBJECT_NAME FORMAT a30
  5. COLUMN EVENT FORMAT a30
  6. SELECT dba_objects.object_name,
  7. dba_objects.object_type,
  8. active_session_history.event,
  9. SUM (active_session_history.wait_time + active_session_history.time_waited) ttl_wait_time
  10. FROM v$active_session_history active_session_history, dba_objects
  11. WHERE active_session_history.sample_time BETWEEN SYSDATE - 60 / 2880 AND SYSDATE
  12. AND active_session_history.current_obj# = dba_objects.object_id
  13. GROUP BY dba_objects.object_name, dba_objects.object_type, active_session_history.event
  14. ORDER BY 4 DESC;

7、寻找基于指定时间范围内的历史SQL语句

  1. --注该查询受到awr快照相关参数的影响
  2. -- filename:top_sql_in_spec_time.sql
  3. --Top SQLs Elaps time and CPU time in a given time range..
  4. --X.ELAPSED_TIME/1000000 => From Micro second to second
  5. --X.ELAPSED_TIME/1000000/X.EXECUTIONS_DELTA => How many times the sql ran
  6. SET PAUSE ON
  7. SET PAUSE 'Press Return To Continue'
  8. SET LINESIZE 180
  9. COL sql_text FORMAT a80 WRAP
  10. SELECT sql_text,
  11. dhst.sql_id,
  12. ROUND (x.elapsed_time / 1000000 / x.executions_delta, 3) elapsed_time_sec,
  13. ROUND (x.cpu_time / 1000000 / x.executions_delta, 3) cpu_time_sec,
  14. x.elapsed_time,
  15. x.cpu_time,
  16. executions_delta AS exec_delta
  17. FROM dba_hist_sqltext dhst,
  18. (  SELECT dhss.sql_id sql_id,
  19. SUM (dhss.cpu_time_delta) cpu_time,
  20. SUM (dhss.elapsed_time_delta) elapsed_time,
  21. CASE SUM (dhss.executions_delta) WHEN 0 THEN 1 ELSE SUM (dhss.executions_delta) END
  22. AS executions_delta
  23. FROM dba_hist_sqlstat dhss
  24. WHERE dhss.snap_id IN
  25. (SELECT snap_id
  26. FROM dba_hist_snapshot
  27. WHERE begin_interval_time >= TO_DATE ('&input_start_date', 'YYYYMMDD HH24:MI')
  28. AND end_interval_time <= TO_DATE ('&input_end_date', 'YYYYMMDD HH24:MI'))
  29. GROUP BY dhss.sql_id) x
  30. WHERE x.sql_id = dhst.sql_id
  31. ORDER BY elapsed_time_sec DESC;

8、寻找基于指定时间范围内及指定用户的历史SQL语句

  1. --注该查询受到awr快照相关参数的影响
  2. --Author : Robinson
  3. --Blog   : http://blog.csdn.net/robinson_0612
  4. SELECT DBMS_LOB.SUBSTR (sql_text, 4000, 1) AS sql,
  5. ROUND (x.elapsed_time / 1000000, 2) elapsed_time_sec,
  6. ROUND (x.cpu_time / 1000000, 2) cpu_time_sec,
  7. x.executions_delta AS exec_num,
  8. ROUND ( (x.elapsed_time / 1000000) / x.executions_delta, 2) AS exec_time_per_query_sec
  9. FROM dba_hist_sqltext dhst,
  10. (  SELECT dhss.sql_id sql_id,
  11. SUM (dhss.cpu_time_delta) cpu_time,
  12. SUM (dhss.elapsed_time_delta) elapsed_time,
  13. CASE SUM (dhss.executions_delta) WHEN 0 THEN 1 ELSE SUM (dhss.executions_delta) END
  14. AS executions_delta
  15. --DHSS.EXECUTIONS_DELTA = No of queries execution (per hour)
  16. FROM dba_hist_sqlstat dhss
  17. WHERE dhss.snap_id IN
  18. (SELECT snap_id
  19. FROM dba_hist_snapshot
  20. WHERE begin_interval_time >= TO_DATE ('&input_start_date', 'YYYYMMDD HH24:MI')
  21. AND end_interval_time <= TO_DATE ('&input_end_date', 'YYYYMMDD HH24:MI'))
  22. AND dhss.parsing_schema_name LIKE UPPER ('%&input_username%')
  23. GROUP BY dhss.sql_id) x
  24. WHERE x.sql_id = dhst.sql_id
  25. ORDER BY elapsed_time_sec DESC;

9、SQL语句被执行的次数

  1. --exe_delta表明在指定时间内增长的次数
  2. -- filename: sql_exec_num.sql
  3. -- How many Times a query executed?
  4. SET LINESIZE 180
  5. SET VERIFY OFF
  6. SELECT TO_CHAR (s.begin_interval_time, 'yyyymmdd hh24:mi:ss'),
  7. sql.sql_id AS sql_id,
  8. sql.executions_delta AS exe_delta,
  9. sql.executions_total
  10. FROM dba_hist_sqlstat sql, dba_hist_snapshot s
  11. WHERE     sql_id = '&input_sql_id'
  12. AND s.snap_id = sql.snap_id
  13. AND s.begin_interval_time > TO_DATE ('&input_start_date', 'YYYYMMDD HH24:MI')
  14. AND s.begin_interval_time < TO_DATE ('&input_end_date', 'YYYYMMDD HH24:MI')
  15. ORDER BY s.begin_interval_time;
  16. 转:http://blog.csdn.net/leshami/article/details/8904804

Oracle 性能相关常用脚本(SQL)的更多相关文章

  1. SqlServer和Oracle中一些常用的sql语句9 SQL优化

    --SQL查询优化 尽量避免使用or,not,distinct运算符,简化连接条件 /*Or运算符*/ use db_business go select * from 仓库 where 城市='北京 ...

  2. SqlServer和Oracle中一些常用的sql语句10 特殊应用

    --482, ORACLE / SQL SERVER --订购数量超过平均值的书籍 WITH Orders_Book AS ( SELECT Book_Name, SUM(Qty) Book_Qty ...

  3. SqlServer和Oracle中一些常用的sql语句3 行列转换

    --217, SQL SERVER SELECT Cust_Name , MAX(CASE WHEN Order_Date ='2009-08-01' THEN AR END) "2009- ...

  4. SqlServer和Oracle中一些常用的sql语句5 流程控制语句

    --在sql语句中 begin...end 用来设定一个程序块 相关于c#中的{} declare @yz real,@w int --声明变量 set @w=120 --为变量赋值 if @w< ...

  5. 常用脚本--SQL Server获取OS日志

    --=================================================== --SQL Server获取OS日志: ), ), ), ) select @start_d ...

  6. SqlServer和Oracle中一些常用的sql语句6 存储过程

    --不带参数的存储过程 CREATE procedure proc_sql1 as begin declare @i int set @i=0 while @i<26 begin print c ...

  7. SqlServer和Oracle中一些常用的sql语句7 游标

    declare db_cursor4 scroll cursor for select * from 供应商 --声明游标 open db_cursor4 --打开游标 fetch first fro ...

  8. SqlServer和Oracle中一些常用的sql语句8 触发器和事务

    --创建和执行事后触发器 --更新仓库备份表中记录时自动创建数据表且插入三条记录 create trigger db_trigger1 on 仓库备份 for update as begin if E ...

  9. SqlServer和Oracle中一些常用的sql语句4 局部/全局变量

    --把wh1仓库号中姓名含有"平"字的职工工资在原来的基础上加288 update 职工备份 set 工资=工资+288 where 仓库号='wh1' and 姓名 like ' ...

随机推荐

  1. DP+矩阵快速幂 HDOJ 5318 The Goddess Of The Moon

    题目传送门 /* DP::dp[i][k] 表示选择i个字符串,最后一次是k类型的字符串,它由sum (dp[i-1][j]) (a[j], a[k] is ok)累加而来 矩阵快速幂:将n个字符串看 ...

  2. C难点分析

    1. 形参和实参 调用函数时,写在括号里面的就是实参,函数本身用的就是形参. 2.字符串问题 char a[5]={"abcd"};注意是4个字符,而不是5个  字符串数组后面带  ...

  3. 数组使用find查询用法

    #include "stdafx.h"#include <string>#include <list>#include <algorithm># ...

  4. TCP建立连接的三次握手过程

    TCP是因特网中的传输层协议,使用三次握手协议建立连接,下面是TCP建立连接的全过程. 上图画出了TCP建立连接的过程.假定主机A运行的是TCP客户程序,B运行的是TCP服务器程序.最初两端的TCP进 ...

  5. CentOS查看系统信息命令和方法

    收集整理的一些linux查看系统信息的命令和方法: 一.linux查看服务器系统信息的方法: 1.查看主机名/内核版本/CPU构架: # uname -n -r -p -o localhost.loc ...

  6. Linux下安装mysql-5.6.4 的图文教程

    在开始安装前,先说明一下mysql-5.6.4与较低的版本在安装上的区别,从mysql-5.5起,mysql源码安装开始使用cmake了,因此当我们配置安装目录./configure --perfix ...

  7. ajax 一个 gbk 目标后内容乱码的解决方案

    ajax 一个 gbk 目标后,如果内容出现乱码,说明服务器在送出内容时没有指定 charset,ajax 对于没有指定 charset 的 response 默认以 utf-8 来处理,所有出现乱码 ...

  8. Combiner

    如果job 设置了 combiner ,则job的每个map运行的数据会先进入combiner,然后再通过patitioner分发到reduce.通过combiner能减少reduce的计算.空间压力 ...

  9. Alpha、 Beta、build、release测试

    alpha(内测) alpha测试是由一个用户在开发环境下进行的测试,也可以是公司内部的用户在模拟实际操作环境下进行的测试.alpha测试的目的是评价软件产品的FLURPS(即功能.局域化.可使用性. ...

  10. log log4net用代码记录日志

    log4net  用代码记录日志 今天在开发项目的时候,遇到跨域调用log4net中的类,出现了一个bug,提示LogImpl未标记可序列化,此时,我靠,麻烦了,这个类又不是咱们自己的,改源码我想应该 ...