今天,一同事的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;
搞定!