欢迎投稿

今日深度:

Oracle查看正在执行的sql语句的方法大全,

Oracle查看正在执行的sql语句的方法大全,


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

      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 
      

      正在执行的sql

      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#'
      

      总结

      到此这篇关于Oracle查看正在执行的sql语句的方法大全的文章就介绍到这了,更多相关Oracle查看sql语句内容请搜索PHP之友以前的文章或继续浏览下面的相关文章希望大家以后多多支持PHP之友!

      您可能感兴趣的文章:
      • 查询Oracle中正在执行和执行过的SQL语句
      • oracle数据库查看锁表的sql语句整理
      • oracle查看执行最慢与查询次数最多的sql语句
      • Oracle表空间查看sql使用情况
      • Oracle查看逻辑读、物理读资源占用排行的SQL语句

      www.htsjk.Com true http://www.htsjk.com/oracle/47705.html NewsArticle Oracle查看正在执行的sql语句的方法大全, 目录 1、查看 Oracle 正在执行的 sql 语句 1.1、杀死进程 1.2、若利用步骤2命令kill一个进程后,进程状态被置为killed,但是锁定的资源很长时间没...
      评论暂时关闭