Oracle 性能相关常用脚本(SQL)

简介:

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

 

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

[sql]  view plain  copy
 
 print?在CODE上查看代码片派生到我的代码片
  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.   
  7. SELECT *  
  8.   FROM (  SELECT sql_text,  
  9.                  sql_id,  
  10.                  executions,  
  11.                  disk_reads,  
  12.                  buffer_gets  
  13.             FROM v$sqlarea  
  14.            WHERE DECODE (executions, 0, buffer_gets, buffer_gets / executions) >  
  15.                     (SELECT AVG (DECODE (executions, 0, buffer_gets, buffer_gets / executions))  
  16.                             + STDDEV (DECODE (executions, 0, buffer_gets, buffer_gets / executions))  
  17.                        FROM v$sqlarea)  
  18.                  AND parsing_user_id != 3D  
  19.         ORDER BY 5 DESC) x  /*更正@20140613,原来为order by 4,感谢网友lmalds指正*/  
  20.  WHERE ROWNUM <= 10;  

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

[sql]  view plain  copy
 
 print?在CODE上查看代码片派生到我的代码片
  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.   
  7. SELECT *  
  8.   FROM (  SELECT sql_text,  
  9.                  sql_id,  
  10.                  executions,  
  11.                  disk_reads,  
  12.                  buffer_gets  
  13.             FROM v$sqlarea  
  14.            WHERE DECODE (executions, 0, disk_reads, disk_reads / executions) >  
  15.                     (SELECT AVG (DECODE (executions, 0, disk_reads, disk_reads / executions))  
  16.                             + STDDEV (DECODE (executions, 0, disk_reads, disk_reads / executions))  
  17.                        FROM v$sqlarea)  
  18.                  AND parsing_user_id != 3D  
  19.         ORDER BY 4 DESC) x  /* 更正@20140613,原来为order by 3,谢谢网友lmalds指正*/  
  20.  WHERE ROWNUM <= 10;  

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

[sql]  view plain  copy
 
 print?在CODE上查看代码片派生到我的代码片
  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.   
  7.   SELECT active_session_history.event,  
  8.          SUM (  
  9.             active_session_history.wait_time  
  10.             + active_session_history.time_waited)  
  11.             total_wait_time  
  12.     FROM v$active_session_history active_session_history  
  13.    WHERE active_session_history.sample_time BETWEEN SYSDATE - 60 / 2880  
  14.                                                 AND SYSDATE  
  15.          AND active_session_history.event IS NOT NULL  
  16. GROUP BY active_session_history.event  
  17. ORDER BY 2 DESC;  

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

[sql]  view plain  copy
 
 print?在CODE上查看代码片派生到我的代码片
  1. --filename:top_wait_by_user.sql  
  2. --What user is waiting the most?  
  3.   
  4. SET LINESIZE 180  
  5. COL event FORMAT a60  
  6. COL total_wait_time FORMAT 999999999999999999  
  7.   
  8.   SELECT ss.sid,  
  9.          NVL (ss.username, 'oracle') AS username,  
  10.          SUM (ash.wait_time + ash.time_waited) total_wait_time  
  11.     FROM v$active_session_history ash, v$session ss  
  12.    WHERE ash.sample_time BETWEEN SYSDATE - 60 / 2880 AND SYSDATE AND ash.session_id = ss.sid  
  13. GROUP BY ss.sid, ss.username  
  14. ORDER BY 3 DESC;  

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

[sql]  view plain  copy
 
 print?在CODE上查看代码片派生到我的代码片
  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.   
  8. SELECT *  
  9.   FROM (  SELECT sqlarea.sql_text,  
  10.                  dba_users.username,  
  11.                  sqlarea.sql_id,  
  12.                  SUM (active_session_history.wait_time + active_session_history.time_waited)  
  13.                     total_wait_time  
  14.             FROM v$active_session_history active_session_history, v$sqlarea sqlarea, dba_users  
  15.            WHERE     active_session_history.sample_time BETWEEN SYSDATE - 60 / 2880 AND SYSDATE  
  16.                  AND active_session_history.sql_id = sqlarea.sql_id  
  17.                  AND active_session_history.user_id = dba_users.user_id  
  18.         GROUP BY active_session_history.user_id,  
  19.                  sqlarea.sql_text,  
  20.                  sqlarea.sql_id,  
  21.                  dba_users.username  
  22.         ORDER BY 4 DESC) x  
  23.  WHERE ROWNUM <= 11;  

6、等待最多的对象

[sql]  view plain  copy
 
 print?在CODE上查看代码片派生到我的代码片
  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.   
  7.   SELECT dba_objects.object_name,  
  8.          dba_objects.object_type,  
  9.          active_session_history.event,  
  10.          SUM (active_session_history.wait_time + active_session_history.time_waited) ttl_wait_time  
  11.     FROM v$active_session_history active_session_history, dba_objects  
  12.    WHERE active_session_history.sample_time BETWEEN SYSDATE - 60 / 2880 AND SYSDATE  
  13.          AND active_session_history.current_obj# = dba_objects.object_id  
  14. GROUP BY dba_objects.object_name, dba_objects.object_type, active_session_history.event  
  15. ORDER BY 4 DESC;  

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

[sql]  view plain  copy
 
 print?在CODE上查看代码片派生到我的代码片
  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.   
  7. SET PAUSE ON  
  8. SET PAUSE 'Press Return To Continue'  
  9. SET LINESIZE 180  
  10. COL sql_text FORMAT a80 WRAP  
  11.   
  12.   SELECT sql_text,  
  13.          dhst.sql_id,  
  14.          ROUND (x.elapsed_time / 1000000 / x.executions_delta, 3) elapsed_time_sec,  
  15.          ROUND (x.cpu_time / 1000000 / x.executions_delta, 3) cpu_time_sec,  
  16.          x.elapsed_time,  
  17.          x.cpu_time,  
  18.          executions_delta AS exec_delta  
  19.     FROM dba_hist_sqltext dhst,  
  20.          (  SELECT dhss.sql_id sql_id,  
  21.                    SUM (dhss.cpu_time_delta) cpu_time,  
  22.                    SUM (dhss.elapsed_time_delta) elapsed_time,  
  23.                    CASE SUM (dhss.executions_delta) WHEN 0 THEN 1 ELSE SUM (dhss.executions_delta) END  
  24.                       AS executions_delta  
  25.               FROM dba_hist_sqlstat dhss  
  26.              WHERE dhss.snap_id IN  
  27.                       (SELECT snap_id  
  28.                          FROM dba_hist_snapshot  
  29.                         WHERE begin_interval_time >= TO_DATE ('&input_start_date', 'YYYYMMDD HH24:MI')  
  30.                               AND end_interval_time <= TO_DATE ('&input_end_date', 'YYYYMMDD HH24:MI'))  
  31.           GROUP BY dhss.sql_id) x  
  32.    WHERE x.sql_id = dhst.sql_id  
  33. ORDER BY elapsed_time_sec DESC;  

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

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

9、SQL语句被执行的次数

[sql]  view plain  copy
 
 print?在CODE上查看代码片派生到我的代码片
  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.   
  7.   SELECT TO_CHAR (s.begin_interval_time, 'yyyymmdd hh24:mi:ss'),  
  8.          sql.sql_id AS sql_id,  
  9.          sql.executions_delta AS exe_delta,  
  10.          sql.executions_total  
  11.     FROM dba_hist_sqlstat sql, dba_hist_snapshot s  
  12.    WHERE     sql_id = '&input_sql_id'  
  13.          AND s.snap_id = sql.snap_id  
  14.          AND s.begin_interval_time > TO_DATE ('&input_start_date', 'YYYYMMDD HH24:MI')  
  15.          AND s.begin_interval_time < TO_DATE ('&input_end_date', 'YYYYMMDD HH24:MI')  
  16. ORDER BY s.begin_interval_time;  
  17. 转:http://blog.csdn.net/leshami/article/details/8904804
文章可以转载,必须以链接形式标明出处。

本文转自 张冲andy 博客园博客,原文链接:http://www.cnblogs.com/andy6/p/5877497.html    ,如需转载请自行联系原作者

相关文章
|
21天前
|
SQL Oracle 关系型数据库
Oracle的PL/SQL隐式游标:数据的“自动导游”与“轻松之旅”
【4月更文挑战第19天】Oracle PL/SQL中的隐式游标是自动管理的数据导航工具,简化编程工作,尤其适用于简单查询和DML操作。它自动处理数据访问,提供高效、简洁的代码,但不适用于复杂场景。显式游标在需要精细控制时更有优势。了解并适时使用隐式游标,能提升数据处理效率,让开发更加轻松。
|
21天前
|
SQL 存储 Oracle
Oracle的PL/SQL定义变量和常量:数据的稳定与灵动
【4月更文挑战第19天】在Oracle PL/SQL中,变量和常量扮演着数据存储的关键角色。变量是可变的“魔术盒”,用于存储程序运行时的动态数据,通过`DECLARE`定义,可在循环和条件判断中体现其灵活性。常量则是不可变的“固定牌”,一旦设定值便保持不变,用`CONSTANT`声明,提供程序稳定性和易维护性。通过 `%TYPE`、`NOT NULL`等特性,可以更高效地管理和控制变量与常量,提升代码质量。善用两者,能优化PL/SQL程序的结构和性能。
|
22小时前
|
SQL 关系型数据库 MySQL
SQL脚本列转行
【5月更文挑战第2天】
4 0
|
1天前
|
SQL 关系型数据库 MySQL
SQL脚本行转列
【5月更文挑战第1天】
7 0
|
15天前
|
SQL Java 关系型数据库
mybatis-plus启动时自动执行sql脚本
mybatis-plus启动时自动执行sql脚本
19 1
|
21天前
|
SQL Oracle 关系型数据库
Oracle的PL/SQL游标自定义异常:数据探险家的“专属警示灯”
【4月更文挑战第19天】Oracle PL/SQL中的游标自定义异常是处理数据异常的有效工具,犹如数据探险家的警示灯。通过声明异常名(如`LOW_SALARY_EXCEPTION`)并在满足特定条件(如薪资低于阈值)时使用`RAISE`抛出异常,能灵活应对复杂业务规则。示例代码展示了如何在游标操作中定义和捕获自定义异常,提升代码可读性和维护性,确保在面对数据挑战时能及时响应。掌握自定义异常,让数据管理更从容。
|
21天前
|
SQL Oracle 安全
Oracle的PL/SQL游标异常处理:从“惊涛骇浪”到“风平浪静”
【4月更文挑战第19天】Oracle PL/SQL游标异常处理确保了在数据操作中遇到的问题得以优雅解决,如`NO_DATA_FOUND`或`TOO_MANY_ROWS`等异常。通过使用`EXCEPTION`块捕获并处理这些异常,开发者可以防止程序因游标问题而崩溃。例如,当查询无结果时,可以显示定制的错误信息而不是让程序终止。掌握游标异常处理是成为娴熟的Oracle数据管理员的关键,能保证在复杂的数据环境中稳健运行。
|
21天前
|
SQL Oracle 安全
Oracle的PL/SQL异常处理方法:守护数据之旅的“魔法盾”
【4月更文挑战第19天】Oracle PL/SQL的异常处理机制是保障数据安全的关键。通过预定义异常(如`NO_DATA_FOUND`)和自定义异常,开发者能优雅地管理错误。异常在子程序中抛出后会向上传播,直到被捕获,提供了一种集中处理错误的方式。理解和善用异常处理,如同手持“魔法盾”,确保程序在面对如除数为零、违反约束等挑战时,能有效保护数据的完整性和程序的稳定性。
|
21天前
|
SQL Oracle 关系型数据库
Oracle的PL/SQL中FOR语句循环游标的奇幻之旅
【4月更文挑战第19天】在Oracle PL/SQL中,FOR语句与游标结合,提供了一种简化数据遍历的高效方法。传统游标处理涉及多个步骤,而FOR循环游标自动处理细节,使代码更简洁、易读。通过示例展示了如何使用FOR循环游标遍历员工表并打印姓名和薪资,对比传统方式,FOR语句不仅简化代码,还因内部优化提升了执行效率。推荐开发者利用这一功能提高工作效率。
|
21天前
|
SQL Oracle 关系型数据库
Oracle的PL/SQL游标属性:数据的“导航仪”与“仪表盘”
【4月更文挑战第19天】Oracle PL/SQL游标属性如同车辆的导航仪和仪表盘,提供丰富信息和控制。 `%FOUND`和`%NOTFOUND`指示数据读取状态,`%ROWCOUNT`记录处理行数,`%ISOPEN`显示游标状态。还有`%BULK_ROWCOUNT`和`%BULK_EXCEPTIONS`增强处理灵活性。通过实例展示了如何在数据处理中利用这些属性监控和控制流程,提高效率和准确性。掌握游标属性是提升数据处理能力的关键。