杀掉JOB

今天,一同事的job不能直接remove掉。

考虑到是job被锁住了。

查看被锁住的JOB

SELECT SID, TYPE, ID1, ID2  

From V$lock  

WHERE TYPE = 'JQ';

确实被锁住了。于是执行了

alter system kill session '305,37075';

来杀掉相关的session。

 

再执行JOB,晕,又给锁住了。

这下子有点郁闷了。

 

原来当kill到刚才的session后,job本身确实不是死锁了。但是还在执行。因为有表被锁了。所以需要额外再杀掉执行JOB所关联的死锁的表。以下SQL可以查看全部的死锁对象。

select

    (select username from v$session where sid=a.sid) blocker,

    a.sid, 'is blocking',

    (select username from v$session where sid=b.sid) blockee,

    b.sid

    from v$lock a,v$lock b

    where a.block=1 and b.request>0

    And A.Id1=B.Id1

    And A.Id2=B.Id2;

执行多次(杀掉相关的全部session)

 

 

alter system kill session 'sid,sieral#';

后,再执行

Begin

Dbms_Job.Remove(741);

Commit;

End;   

 

搞定!

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值