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

GBase 8c 咨询锁函数

李雨晴 2022-07-26
305

咨询锁函数用于管理咨询锁(Advisory Lock)。

pg_advisory_lock(key bigint)

描述:获取会话级别的排它咨询锁。

返回值类型:void

备注:pg_advisory_lock锁定应用程序定义的资源,该资源可以用一个64位或两个不重叠的32位键值标识。如果已经有另外的会话锁定了该资源,则该函数将阻塞到该资源可用为止。这个锁是排它的。多个锁定请求将会被压入栈中,因此,如果同一个资源被锁定了三次,它必须被解锁三次以将资源释放给其他会话使用。

pg_advisory_lock(key1 int, key2 int)

描述:获取会话级别的排它咨询锁。

返回值类型:void

备注:只允许sysadmin对键值对(65535, 65535)加会话级别的排它咨询锁,普通用户无权限。

pg_advisory_lock(int4, int4, Name)

描述:获取指定数据库的排它咨询锁。

返回值类型:void

pg_advisory_lock_shared(key bigint)

描述:获取会话级别的共享咨询锁。

返回值类型:void

pg_advisory_lock_shared(key1 int, key2 int)

描述:获取会话级别的共享咨询锁。

返回值类型:void

备注:pg_advisory_lock_shared类似于pg_advisory_lock,不同之处仅在于共享锁会话可以和其他请求共享锁的会话共享资源,但排它锁除外。

pg_advisory_unlock(key bigint)

描述:释放会话级别的排它咨询锁。

返回值类型:Boolean

pg_advisory_unlock(key1 int, key2 int)

描述:释放会话级别的排它咨询锁。

返回值类型:Boolean

备注:pg_advisory_unlock释放先前取得的排它咨询锁。如果释放成功则返回true。如果实际上并未持有指定的锁,将返回false并在服务器中产生一条SQL警告信息。

pg_advisory_unlock(int4, int4, Name)

描述:释放指定数据库上的排它咨询锁。

返回值类型:Boolean

备注:如果释放成功则返回true;如果未持有锁,则返回false。

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

评论