oracle 存储过程不能编译-- (编译的同时正在访问所导致的) [转载]

oracle 存储过程不能编译-- (编译的同时正在访问所导致的)  [转载]

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;

 

 

本文转载:http://www.cnblogs.com/kaka-bing/archive/2012/06/28/2568501.html

你可能感兴趣的:(oracle 存储过程不能编译-- (编译的同时正在访问所导致的) [转载])