oracle根据pid查询出正在执行的执行语句

       今天数据库访问突然很慢,通过top命令发现oracle的cpu使用率很高。同事建议查询一下看看是什么语句导致的oracle运行变慢。于是从网上查了一下,可以根据pid查询出正在执行的查询语句,发现是一个大表的字段没有创建索引导致全表扫描。具体操作步骤如下:

  • 切换到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;

 

posted @ 2015-08-25 17:29  wala-wo  阅读(1774)  评论(0编辑  收藏  举报