ORACLE存储过程,函数加锁

原创 2011年01月25日 10:51:00

 

最近碰到比较头痛的事情,原来单域部署的的应用变成了集群部署,这样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;


--你要锁住的业务逻辑代码


LN := DBMS_LOCK.release (lockhandle);--释放资源


测试方法,启动线程1,在业务逻辑处打断点,锁住存过,启动线程2执行存过,发现已经卡死;继续执行线程1存过指导解锁,发现线程2锁死情况等待2秒后解除,为了达到更好的效果,可以设置休眠时间更长一些

附:  

DBMS_LOCK.request 返回值

0 申请锁定成功

1 申请锁定时超时

2 申请锁定时发生死锁

3 传入参数错误

4 已经获得了锁定,重复申请了锁

5 传入的锁定句柄错误

DBMS_LOCK.release 返回值

0 释放锁定成功

3 传入参数错误

4 并没有获得要释放的锁定

5 传入的锁定句柄错误

ORACLE—009:存储过程加锁

最近碰到一种情况,需要限制某个存储过程只能有一个进程在执行,上一个执行完毕后下一个再执行。也就是类似与程序开发中的线程同步问题。汇总一个下,可以通过如下方法来实现。1、设置一个变量,或者表中的某个字段...

Oracle中的锁(LOCK)机制

本文结合示例简要的介绍了一下Oracle中锁的机制。

ORACLE 存储过程被锁,编译不了,怎么解锁

可用SYS登录,然后查询如下语句: 查找存储过程OPERATIONDATA_IMP被哪些session锁住而无法编译 select * FROM dba_ddl_locks where name ...

ORACLE-Kill 杀死正在执行的Oracle存储过程和死锁语句

存储过程 1、找到正在执行的存储过程的 sid ,serial#       select   b.sid,b.SERIAL#,a.OBJECT, 'alter system kill ses...

oracle函数调用存储过程

  • 2012年06月26日 11:01
  • 47KB
  • 下载

oracle 函数和存储过程

6.1 引言 6.2 创建函数 6.3 存储过程 6.3.1 创建过程 6.3.2 调用存储过程 6.3.3 AUTHID 6.3.4 PRAGMA AUTONOMOUS_TRANSACT...

Oracle存储过程及函数的练习题

--实训题--(1)创建一个存储过程,以员工号为参数,输出该员工的工资create or replace procedure p_sxt1(v_empno in emp.empno%type, v_s...
  • myinc
  • myinc
  • 2013年12月05日 17:06
  • 6452
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ORACLE存储过程,函数加锁
举报原因:
原因补充:

(最多只允许输入30个字)