oracle查询进行中进程与解决死锁

oracle数据库使用过程中,可能会出现死锁等情况,需要通过sql查询哪些语句导致死锁,及解决死锁问题,处理方式如下:

注意:以下sql可能存在执行权限问题,可能需要使用sysadmin等高权限的账号进行执行

一、查询进行中的进程SQL

如果服务器上对应有多个表空间或用户,可以在where条件中指定USERAME

SELECT b.sid,
       b.serial#,
       b.username,
       b.machine,
       b.paddr,
       b.event,
       to_char(b.sql_exec_start,'yyyy-mm-dd hh24:mi:ss') sql_exec_start,
       --sa.sql_text,
       --dbms_lob.substr(sa.sql_fulltext, 3000),
       sa.version_count,
       sa.plan_hash_value,
       sa.sql_id,
       sa.sql_fulltext,
       sa.executions, --执行次数
       round(sa.cpu_time / 1000000, 2) total_cpu_time_SECOND, --总CPU执行时间 单位秒
       round(sa.elapsed_time / 1000000, 2) total_elapsed_time_SECOND, --总执行时间 单位秒
       round(sa.elapsed_time / 1000000 / decode(sa.executions,0,1,sa.executions), 2) avg_elapsed_time_SECOND, --平均执行时间 单位秒
       round(sa.buffer_gets,2) buffer_gets, --读缓存区次数
       sa.physical_read_requests, --IO请求数
       sa.disk_reads disk_reads, --磁盘读次数
       round(sa.physical_read_bytes/1024/1024,2) physical_read_MB, --物理读 单位M
       --round(sa.direct_reads,2) direct_reads,
       round(sa.physical_write_bytes/1024/1024,2) physical_write_MB, --物理写 单位M
       --round(sa.direct_writes,2) direct_writes,
       sa.fetches,
       round(sa.rows_processed/decode(sa.executions,0,1,sa.executions),2) avg_rows_processed, --平均每次处理的行数
       sa.sorts,
       sa.optimizer_cost,
       'alter system kill session ' || '''' || b.sid || ',' ||b.SERIAL# ||',@' || b.inst_id ||''';' kill_command
  FROM gv$session b, gv$sqlarea sa
 WHERE b.sql_hash_value = hash_value
   and b.sql_address = address
   and b.inst_id = sa.inst_id
   --and b.sql_exec_start >= sysdate -300/24/60/60;
   --and round(sa.elapsed_time / 1000000 / decode(sa.executions,0,1,sa.executions), 2) > 30
 order by round(sa.elapsed_time / 1000000 / decode(sa.executions,0,1,sa.executions), 2)  desc;

二、执行相关KILL_COMMAND

可以先提前看下SQL_FULLTEXT里的内容是什么,目前正在执行的sql均包含在其中

三、数据库服务器上杀死进程

部分sql可能使用kill_command无法删除,或者要花很长时间,此时我们可以考虑直接去服务器上进行处理

1、查询相关线程id(其中sid可用前面查询出来的sid)

--数据库 session id
select sid from v$session

--linux操作系统进程 或者 windows线程  (线程要根据session id 查询)
select spid from v$process t where t.addr in (select paddr from v$session where sid = '上面的sid传到这里' );

2、windows服务器杀死进程

访问数据库服务器,启动ProcessExplorer软件并双击oracle.exe

根据前面查出来的sid,即该软件中的TID,选中对应的进程,并点击“kill”

之后点击“确定”,等待几秒后即可杀死该进程

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值