暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

华为GaussDB T 获取锁GET_LOCK

原创 章芋文 2019-09-22
706

GET_LOCK(name_expr [, timeout_expr])

功能:GET_LOCK() 为一个会话获取一把锁名为name_expr的咨询锁(advisory lock),之后另一个会话若也调用GET_LOCK()尝试获取同名锁时,将会等待timeout_expr所指定的秒数。如果在此期间内第一个会话释放了锁,则第二个会话将能成功获取锁;如果时间超过指定的超时秒数后第一个会话仍未释放锁,则第二个会话获取锁的尝试失败。

GET_LOCK()的返回值如下:

  1: 成功获取到锁。

  0: 未能获取到锁。

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

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

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

说明:

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

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

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

  timeout_expr未指定或指定为一个负值时,GET_LOCK()获取不到锁时将一直等待。

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论