Oracle檢視歷史TOP SQL

chenoracle發表於2018-06-22
Oracle 檢視歷史TOP SQL


歷史TOP SQL可以透過AWR直接檢視,
但是有時AWR資訊顯示不全,預設只顯示TOP 10,
可以透過dba_hist_sqltext,dba_hist_sqlstat等檢視更詳細的資訊;


---檢視快照資訊
---選擇2018-06-14全天的快照6504-6528;
---conn chenjch/chenjch
select SNAP_ID,
       DBID,
       to_char(BEGIN_INTERVAL_TIME, 'yyyy-mm-dd hh24:mi:ss'),
       to_char(END_INTERVAL_TIME, 'yyyy-mm-dd hh24:mi:ss'),
       FLUSH_ELAPSED,
       SNAP_LEVEL
  from dba_hist_snapshot order by 1;

---1 檢視2018-06-14全天SQL ordered by Elapsed Time  
---時間單位預設microseconds
select a.sql_id,
       a.module,
       a.elap,
       a.exec,
       decode(a.exec, 0, to_number(null), (a.elap / a.exec)) elap_one,
       b.sql_text
  from dba_hist_sqltext b,
       (select sql_id,
               max(module) module,
               sum(elapsed_time_delta) / 1000000 elap,
               sum(executions_delta) exec
          from dba_hist_sqlstat
         where dbid = 1000919065
           and instance_number = 1
           and 6504 < snap_id
           and snap_id <= 6528
         group by sql_id) a
 where a.sql_id = b.sql_id
 order by elap desc;

---2 檢視2018-06-14全天SQL ordered by Gets
---時間單位預設microseconds
select a.sql_id,
       a.module,
       a.bget,      
       decode(a.exec, 0, to_number(null), a.bget / a.exec) get_per_exec,
       a.exec,
       (a.cput/1000000)/elap*100 CPU,  
       a.elap,
       b.sql_text
  from dba_hist_sqltext b,
       (select sql_id,
               max(module) module,
               sum(buffer_gets_delta) bget,
               sum(executions_delta) exec,
               sum(cpu_time_delta) cput,
               sum(elapsed_time_delta) / 1000000 elap
          from dba_hist_sqlstat
         where dbid = 1000919065
           and instance_number = 1
           and 6504 < snap_id
           and snap_id <= 6528
         group by sql_id) a
 where a.sql_id = b.sql_id
 order by bget desc;

---3 檢視2018-06-14全天SQL ordered by Reads
---時間單位預設microseconds   
select a.sql_id,
       a.module,
       a.diskread,
       a.exec,
       decode(a.exec, 0, to_number(null), a.diskread / a.exec) diskread_one,
       (a.cput/1000000)/elap*100 CPU,
       a.elap,
       b.sql_text
  from dba_hist_sqltext b,
       (select sql_id,
               max(module) module,
               sum(disk_reads_delta) diskread,
               sum(executions_delta) exec,
               sum(cpu_time_delta) cput,
               sum(elapsed_time_delta) / 1000000 elap
          from dba_hist_sqlstat
         where dbid = 1000919065
           and instance_number = 1
           and 6504 < snap_id
           and snap_id <= 6528
         group by sql_id) a
 where a.sql_id = b.sql_id
 order by diskread desc;
  歡迎關注我的微信公眾號"IT小Chen",共同學習,共同成長!!!

Oracle檢視歷史TOP SQL

Oracle檢視歷史TOP SQL



來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29785807/viewspace-2156502/,如需轉載,請註明出處,否則將追究法律責任。

相關文章