停止后台正在运行的存储过程
1.SELECT * FROM V$DB_OBJECT_CACHE WHERE name='NCCM_MEDICAL_USERSTATS2' AND LOCKS!='0';
2.select SID from V$ACCESS WHERE object='NCCM_MEDICAL_USERSTATS2';
3.SELECT SID,SERIAL#,PADDR FROM V$SESSION WHERE SID='135';
4.alter system kill session '135,50430' immediate;
在对存储过程进行访问、运行、测试的时候,没有完全停止,就又在另外一个窗口,对它进行修改而且进行编译,出现了卡死现象。用PLSQL Developer 在session里,找到这条session的记录,然后kill后,再重新编译这个过程,还是卡死,可是在session里这条记录已经是显示killed状态,那就通过下面的方法进行解决:
1:查V$DB_OBJECT_CACHE
SELECT * FROM V$DB_OBJECT_CACHE WHERE name='P_DATA_SYNC_CHECK' AND LOCKS!='0';
注意:P_DATA_SYNC_CHECK为存储过程的名称。
发现locks=2,
2:按对象查出sid的值
select SID from V$ACCESS WHERE object='P_DATA_SYNC_CHECK';
注意:P_DATA_SYNC_CHECK为存储过程的名称。
3:查sid,serial#
SELECT SID,SERIAL#,PADDR FROM V$SESSION WHERE SID='刚才查到的SID';
4:alter system kill session 'sid值,serial#值' immediate;
select b.sid,b.serial#,a.object, 'alter system kill session ' || '''' || b.sid || ',' ||b.serial# || ''';' kill_command
from sys.v_$access a, sys.v_$session b
where a.type IN ('PACKAGE','PACKAGE BODY')
and a.object ='PKG_ETL'
and a.sid = b.sid
and b.status = 'active';