通過spid,查詢執行慢的sql指令碼

pwz1688發表於2014-01-06

通過top命令,可檢視佔用cpu資源極高的程式,得到spid,通過以下sql ,可查詢此程式執行的具體sql

點選(此處)摺疊或開啟

  1. SQL> edit
  2. 已寫入 file afiedt.buf

  3.   1 select
  4.   2 sql_text
  5.   3 from v$sqltext a
  6.   4 where (a.hash_value,a.address) in(
  7.   5 select decode(sql_hash_value,0,prev_hash_value,sql_hash_value),
  8.   6 decode(sql_hash_value,0,prev_sql_addr,sql_address)
  9.   7 from v$session b
  10.   8 where b.paddr=(select addr from v$process c
  11.   9 where c.spid='&pid'))
  12.  10* order by piece asc
  13. SQL> /
  14. 輸入 pid 的值: 4016
  15. 原值 9: where c.spid='&pid'))
  16. 新值 9: where c.spid='4016'))

  17. SQL_TEXT
  18. ----------------------------------------------------------------

  19. select sql_text from v$sqltext a where (a.hash_value,a.address)
  20.  in( select decode(sql_hash_value,0,prev_hash_value,sql_hash_val
  21. ue), decode(sql_hash_value,0,prev_sql_addr,sql_address) from v$s
  22. ession b where b.paddr=(select addr from v$process c where c.spi
  23. d='4016')) order by piece asc

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

相關文章