【ORACLE】查看正在运行的的SQL【全】
作者:mmseoamin日期:2023-12-05

文章目录

  • 前言
    • 1、查看 Oracle 正在执行的 sql 语句
      • 1.1、杀死进程
      • 1.2、若利用步骤2命令kill一个进程后,进程状态被置为"killed",但是锁定的资源很长时间没有被释放,那么可以在os级别再kill相应的进程(线程)。
      • 2、查询当前用户正在执行的SQL
      • 3、查询当前被锁的表
        • 3.1、解除锁命令
        • 总结

          前言

          Oracle语句记录


          1、查看 Oracle 正在执行的 sql 语句

          SELECT b.sid oracleID,  
                 b.username 用户名,  
                 b.serial#,  
                 paddr,  
                 sql_text 正在执行的SQL,  
                 b.machine 计算机名称
          FROM v$process a, v$session b, v$sqlarea c  
          WHERE a.addr = b.paddr  
             AND b.sql_hash_value = c.hash_value 
          

          【ORACLE】查看正在运行的的SQL【全】,正在执行的sql,第1张

          1.1、杀死进程

          ALTER system KILL SESSION '{ORACLEID},{SERIAL#}';
          

          1.2、若利用步骤2命令kill一个进程后,进程状态被置为"killed",但是锁定的资源很长时间没有被释放,那么可以在os级别再kill相应的进程(线程)。

          • 1)首先通过执行下面SQL获得PID:
            SELECT spid, osuser, s.program
            FROM v$session s, v$process p
            WHERE s.paddr=p.addr AND s.sid={ORACLEID};
            
            • 2)在OS上kill这个进程
              -- pid: 获取到的spid
              $ kill -9 {pid}
              

              2、查询当前用户正在执行的SQL

              select a.sid,
                     a.serial#,
                     a.paddr,
                     a.machine,
                     nvl(a.sql_id, a.prev_sql_id) sql_id,
                     b.sql_text,
                     b.sql_fulltext,
                     b.executions,
                     b.first_load_time,
                     b.last_load_time,
                     b.last_active_time,
                     b.disk_reads,
                     b.direct_writes,
                     b.buffer_gets
                from v$session a, v$sql b
               where a.username = sys_context('USERENV', 'CURRENT_USER')
                 and a.status = 'ACTIVE' 
                 and nvl(a.sql_id, a.prev_sql_id) = b.sql_id;
              

              3、查询当前被锁的表

              SELECT l.session_id sid,  
                     s.serial#,  
                     l.locked_mode 锁模式,  
                     l.oracle_username 登录用户,  
                     l.os_user_name 机器用户名,  
                     s.machine 机器名,  
                     s.terminal 终端用户名,  
                     o.object_name 被锁对象名,  
                     s.logon_time 登录数据库时间  
              FROM v$locked_object l, all_objects o, v$session s  
              WHERE l.object_id = o.object_id  
                 AND l.session_id = s.sid  
              ORDER BY sid, s.serial#; 
              

              3.1、解除锁命令

              alter system kill session 'sid,serial#'
              

              总结

              如果此篇文章有帮助到您, 希望打大佬们能关注、点赞、收藏、评论支持一波,非常感谢大家!

              如果有不对的地方请指正!!!

              参考1

              参考2