oracle根據pid查詢出正在執行的執行語句

       今天數據庫訪問忽然很慢,經過top命令發現oracle的cpu使用率很高。同事建議查詢一下看看是什麼語句致使的oracle運行變慢。因而從網上查了一下,能夠根據pid查詢出正在執行的查詢語句,發現是一個大表的字段沒有建立索引致使全表掃描。具體操做步驟以下:sql

  • 切換到oracle帳戶下並輸入密碼

 

       su - oracle

 

  • 經過sqlplus nolog進入命令查詢界面

 

       sqlplus /nolog

 

  • 鏈接進入sysdba帳戶

 

       connect sysdba

 

  • 執行如下sql語句

 

    SELECT
        sql_text
    FROM v$sqltext a
    WHERE (a.hash_value, a.address) IN
    (SELECT DECODE(sql_hash_value, 0, prev_hash_value, sql_hash_value),
    DECODE(sql_hash_value, 0, prev_sql_addr, sql_address)
    FROM v$session b
    WHERE b.paddr =
    (SELECT addr FROM v$process c WHERE c.spid = '21340'))
    ORDER BY piece ASC;
相關文章
相關標籤/搜索