使用V$ACTIVE_SESSION_HISTORY视图,查看消耗资源的sql

来源:互联网 发布:常用端口 编辑:程序博客网 时间:2024/06/08 17:36
  1. --查找最近一分钟内,最消耗CPU的sql语句   
  2. SELECT sql_id,   
  3.     count(*),   
  4.     round(count(*) / sum(count(*)) over(), 2) pctload  
  5. FROM V$ACTIVE_SESSION_HISTORY  
  6. WHERE sample_time > sysdate - 1 / (24 * 60)  
  7.     AND session_type <> 'BACKGROUND'  
  8.     AND session_state = 'ON CPU'  
  9. GROUP BY sql_id  
  10. ORDER BY count(*) desc;  
  11.   
  12. --查找最近一分钟内,最消耗I/O的sql语句  
  13. SELECT ash.sql_id,  
  14.     count(*)  
  15. FROM V$ACTIVE_SESSION_HISTORY ASH,V$EVENT_NAME EVT  
  16. WHERE ash.sample_time > sysdate -1/(24*60)  
  17.     AND ash.session_state = 'WAITING'  
  18.     AND ash.event_id = evt.event_id  
  19.     AND evt.wait_class = 'USER I/O'  
  20. GROUP BY ash.sql_id  
  21. ORDER BY count(*) desc;  
  22.   
  23. --查找最近一分钟内,最消耗CPU的session  
  24. SELECT session_id,  
  25.     count(*)  
  26.     FROM V$ACTIVE_SESSION_HISTORY  
  27. WHERE session_state = 'ON CPU'  
  28.     AND sample_time > sysdate -1/(24*60)  
  29. GROUP BY session_id  
  30. ORDER BY count(*) desc;  
  31.   
  32. --查找最近一分钟内,最消耗资源的sql语句  
  33. SELECT ash.sql_id,  
  34.     sum(decode(ash.session_state,'ON CPU',1,0)) "CPU",  
  35.     sum(decode(ash.session_state,'WAITING',1,0)) -  
  36.     sum(decode(ash.session_state,'WAITING',decode(en.wait_class,'USER I/O',1,0),0)) "WAIT",  
  37.     sum(decode(ash.session_state,'WAITING',decode(en.wait_class,'USER I/O',1,0),0)) "IO",  
  38.     sum(decode(ash.session_state,'ON CPU',1,1)) "TOTAL"  
  39.     FROM V$ACTIVE_SESSION_HISTORY ASH,V$EVENT_NAME EN  
  40. WHERE SQL_ID is not null and en.event#=ash.event# and ash.sample_time > sysdate -1/(24*60)  
  41. GROUP BY ash.sql_id  
  42. ORDER BY sum(decode(ash.session_state,'ON CPU',1,1)) desc;  
  43.   
  44. --查找最近一分钟内,最消耗资源的session  
  45. SELECT ash.session_id,  
  46.     ash.session_serial#,  
  47.     ash.user_id,  
  48.     ash.program,  
  49.     sum(decode(ash.session_state,'ON CPU',1,0)) "CPU",  
  50.     sum(decode(ash.session_state,'WAITING',1,0)) -  
  51.     sum(decode(ash.session_state,'WAITING',decode(en.wait_class,'USER I/O',1,0),0)) "WAITING",  
  52.     sum(decode(ash.session_state,'WAITING',decode(en.wait_class,'USER I/O',1,0),0)) "IO",  
  53.     sum(decode(ash.session_state,'ON CPU',1,1)) "TOTAL"  
  54. FROM V$ACTIVE_SESSION_HISTORY ASH,V$EVENT_NAME EN  
  55. WHERE en.event# = ash.event# and ash.sample_time > sysdate -1/(24*60)  
  56. GROUP BY ash.session_id,ash.user_id,ash.session_serial#,ash.program  
  57. ORDER BY sum(decode(ash.session_state,'ON CPU',1,1));  
0 0
原创粉丝点击