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