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

华为GaussDB T 获取共享锁 GET_SHARED_LOCK

原创 章芋文 2019-09-22
813

GET_SHARED_LOCK

GET_SHARED_LOCK(name_expr [, timeout_expr])

功能:GET_SHARED_LOCK()为一个会话获取一把锁名为name_expr的共享咨询锁,之后另一个会话也可调用GET_SHARED_LOCK()获取该同名锁;如果该锁已被其他会话锁为排他咨询锁,则将会等待参数timeout_expr所指定的秒数结束后获取锁失败,在此期间内若该排他锁被释放了,或只有本会话使用该锁,则获取该锁成功。

GET_SHARED_LOCK()的返回值如下:

        TRUE: 成功获取到锁。

        FALSE: 未能获取到锁。


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

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

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


说明:

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

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

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

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

         TRY_GET_SHARED_LOCK(name_expr)尝试获取名为name_expr的会话级共享咨询锁,无论获取成功或失败都立刻返回结果。

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

评论