ORACLE存储过程,函数加锁

在集群部署的应用中,原本的Java锁失去作用。本文介绍了如何在Oracle存储过程中使用DBMS_LOCK进行加锁,确保业务逻辑单次通过。通过在存储过程内部请求和释放锁,实现了跨实例的同步。测试验证了这种方法的有效性,当一个会话持有锁时,其他会话将等待直到锁被释放。

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

 

最近碰到比较头痛的事情,原来单域部署的的应用变成了集群部署,这样java中锁(lock)就失去了效应,因为变成了多实例,于是实现过程采用存储过程来封装业务逻辑,但是之前没有针对于存储过程加锁的经历。

经过翻阅Oracle资料,发现Oralce可以针对存储过程上锁,保证业务逻辑单次通过,已测试验证,特分享下。

在存过的代码里加入下列代码:

 DBMS_LOCK.allocate_unique ('Lock', lockhandle);--针对当前session加锁

   LOOP
      LN := DBMS_LOCK.request (lockhandle, TIMEOUT => 0);

      IF LN NOT IN (0, 4)--判断是否被别session锁住
      THEN
         DBMS_OUTPUT.put_line ('Already run...');
         DBMS_LOCK.sleep (2);--已经被人锁住,休眠2秒
      ELSE
         EXIT;--没有锁,退出轮询
      END IF;
   END LOOP;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值