Oracle表锁或行锁问题解决办法

1 篇文章 0 订阅
1 篇文章 0 订阅

今天在调试业务问题的时候,刚开始Insert除了数据不对其他倒是没问题,经过不断修改代码,不断调试,最后悲剧发生了,当执行到某一条Insert语句的时候,一直执行不下去,将这条sql语句摘出来在PLSQL中执行,发现一直在执行中,强行结束后报出两个触发器的错误,不明所以,最后发现不知道哪位高手改了触发器没有编译(经常出现这种问题,不想吐槽了),将触发器编译后还是会卡在这个地方,在PLSQL中Test单步调试后,最后发现卡在一个触发器中,关键是这个触发器第一行就return掉了,什么也没执行,然后就卡在那,实在摸不着头脑,郁闷的找了半天,最后在同事中找到了共鸣。

因为Oracle表锁或行锁的问题,至于怎么发生的,我猜测是我在执行的时候有人在修改触发器,导致了悲剧,解决办法如下:       

declare cursor mycur is  
select b.sid,b.serial#  
  from v$locked_object a,v$session b  
  where a.session_id = b.sid group by b.sid,b.serial#;  
  
begin  
  for cur in mycur  
    loop    
     execute immediate ( 'alter system  kill session  '''||cur.sid || ','|| cur.SERIAL# ||''' ');  
     end loop;  
end; 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值