绑定完请刷新页面
取消
刷新

分享好友

×
取消 复制
GaussDB 100 TRY_GET_LOCK函数
2020-02-26 15:29:25

1.1.1    TRY_GET_LOCK

语法:

TRY_GET_LOCK(name_expr)

功能:TRY_GET_LOCK(name_expr) 为一个会话尝试获取一把锁名为name_expr的排他咨询锁(exclusive advisory lock),若获取成功返回TRUE,之后另一个会话若也调用TRY_GET_LOCK(name_expr)尝试获取同名锁时,将会立刻返回FALSE,获取同名锁失败,直到该锁释放。

TRY_GET_LOCK()的返回值如下:

·         TRUE: 成功获取到锁。

·         FALSE: 未能获取到锁。

通过TRY_GET_LOCK(name_expr)获取到的锁可通过以下两种方式释放:

·         显式释放:通过调用RELEASE_LOCK()释放。

·         隐式释放:会话中断(不论正常或异常)时该会话占有的锁自动释放。

说明:

·         表示锁名的name_expr的计算结果的字符串长度不能超过64字节。

·         同一个会话同时多可以加32把锁。

·          同一会话可以多次对同一个锁名上锁,这种情况下,需要对该锁名解锁同样的次数。对同一锁名多次加锁时,第二次加锁开始的次数并不计入上述所说的32把锁的个数。


分享好友

分享这个小栈给你的朋友们,一起进步吧。

GaussDB_数据库
创建时间:2020-01-06 16:21:44
华为GaussDB数据库小栈
展开
订阅须知

• 所有用户可根据关注领域订阅专区或所有专区

• 付费订阅:虚拟交易,一经交易不退款;若特殊情况,可3日内客服咨询

• 专区发布评论属默认订阅所评论专区(除付费小栈外)

技术专家

查看更多
  • GaussDB_数据库
    专家
戳我,来吐槽~