Oracle 查看存储过程占用,及编译时卡住问题

查看存储过程是否有锁住

--LOCKS!='0' 即表示有锁,正在执行
--name 这里也可以用like来模糊拆线呢
 SELECT * FROM V$DB_OBJECT_CACHE WHERE name='存储过程名称' AND LOCKS!='0';

找到锁住过程的SID

---object这里一样可以用 like  模糊
select  SID from V$ACCESS WHERE object='存储过程名称';

查看锁住存储过程对象的设备信息

包括是那台机器锁定的,什么时间锁住的,等等都可以通过以下语句查到

 SELECT *  FROM V$SESSION WHERE SID='SID';

强制kill进程

  • 先找到要杀死进程的sid 和 serial#
SELECT SID,SERIAL#,PADDR FROM V$SESSION WHERE SID='sid';
  • 然后进行kill

注意, 这里的alter命令,可以加immediate 也可以不加immediate
区别是
加immediate ,表示标记执行,类似异步吧
不加immediate:表示直接立即执行,这个时候有可能出现plsql程序假死的情况。
推荐加上 immediate

alter system kill session 'sid值,serial#值' immediate;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

何浩翔

如果对你多帮助,请支持。感谢!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值