oracle 存储过程锁表解锁

本文介绍了如何使用SQL语句解锁被锁定的存储过程。首先需要查找被锁定的存储过程,然后找到对应的会话ID(SID)和序列号(Serial#),最后通过这些信息来终止锁定的会话。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

存储过程解锁语法如下,前提是要有dba权限,不然会提示表或者视图不存在。

--1.查找用户user下的被锁定的存储过程
select * from V$DB_OBJECT_CACHE where owner='user' AND LOCKS!='0';
--2.通过查出来的存储过程名查找sid
select sid,sql_text from v$open_cursor where UPPER(sql_text) like '%procedure_name%';
SELECT spid
FROM V$DB_OBJECT_CACHE   OC,
       V$OBJECT_DEPENDENCY OD,
       DBA_KGLLOCK         W,
       V$SESSION           S,
       V$PROCESS           P
WHERE OD.TO_OWNER = OC.OWNER
   AND OD.TO_NAME = OC.NAME
   AND OD.TO_ADDRESS = W.KGLLKHDL
   AND W.KGLLKUSE = S.SADDR
   AND P.ADDR = S.PADDR
AND OC.NAME = 'procedure_name';
--3.通过sid查找serial#
select sid,serial#,paddr from v$session where sid='1212';--983   1212
--4.杀死会话参数为查出来的sid和serial#
alter system kill session '1212,29203' immediate;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

菜菜的中年程序猿

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值