zoukankan      html  css  js  c++  java
  • 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;
    
  • 相关阅读:
    全局变量、局部变量
    结构体位域
    关键字(static const volatile extern sizeof)
    预处理#
    头文件<time.h>
    头文件<string.h>
    头文件<stdlib.h>
    session 入库
    php中的匿名函数和闭包
    redis 的 RDB 和 AOF 持久化的区别
  • 原文地址:https://www.cnblogs.com/wala-wo/p/5119189.html
Copyright © 2011-2022 走看看