停止后台正在运行的存储过程

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';

posted @ 2013-12-05 15:51  bj_google  阅读(834)  评论(0编辑  收藏  举报