云数据库 GAUSSDB-咨询锁函数
咨询锁函数
咨询锁函数用于管理咨询锁(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(lock_id int4, lock_id int4, datebase_name Name)
描述:通过传入锁ID和数据库名字,获取指定数据库的排他咨询锁。
返回值类型: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(lock_id int4, lock_id int4, datebase_name Name)
描述:通过传入锁ID和数据库名字,释放指定数据库上的排他咨询锁。
返回值类型:Boolean
备注:如果释放成功则返回true;如果未持有锁,则返回false。
- pg_advisory_unlock_shared(key bigint)
返回值类型:Boolean
- pg_advisory_unlock_shared(key1 int, key2 int)
返回值类型:Boolean
备注:pg_advisory_unlock_shared类似于pg_advisory_unlock,不同之处在于该函数释放的是共享咨询锁。
- pg_advisory_unlock_all()
返回值类型:void
备注:pg_advisory_unlock_all将会释放当前会话持有的所有咨询锁,该函数在会话结束的时候被隐含调用,即使客户端异常地断开连接也是一样。
- pg_advisory_xact_lock(key bigint)
返回值类型:void
- pg_advisory_xact_lock(key1 int, key2 int)
返回值类型:void
备注:pg_advisory_xact_lock类似于pg_advisory_lock,不同之处在于锁是自动在当前事务结束时释放,而且不能被显式的释放。只允许sysadmin对键值对(65535, 65535)加事务级别的排他咨询锁,普通用户无权限。
- pg_advisory_xact_lock_shared(key bigint)
返回值类型:void
- pg_advisory_xact_lock_shared(key1 int, key2 int)
返回值类型:void
备注:pg_advisory_xact_lock_shared类似于pg_advisory_lock_shared,不同之处在于锁是在当前事务结束时自动释放,而且不能被显式的释放。
- pg_try_advisory_lock(key bigint)
返回值类型:Boolean
备注:pg_try_advisory_lock类似于pg_advisory_lock,不同之处在于该函数不会阻塞以等待资源的释放。它要么立即获得锁并返回true,要么返回false表示目前不能锁定。
- pg_try_advisory_lock(key1 int, key2 int)
返回值类型:Boolean
备注:只允许sysadmin对键值对(65535, 65535)加会话级别的排他咨询锁,普通用户无权限。
- pg_try_advisory_lock_shared(key bigint)
返回值类型:Boolean
- pg_try_advisory_lock_shared(key1 int, key2 int)
返回值类型:Boolean
备注:pg_try_advisory_lock_shared类似于pg_try_advisory_lock,不同之处在于该函数尝试获得共享锁而不是排他锁。
- pg_try_advisory_xact_lock(key bigint)
返回值类型:Boolean
- pg_try_advisory_xact_lock(key1 int, key2 int)
返回值类型:Boolean
备注:pg_try_advisory_xact_lock类似于pg_try_advisory_lock,不同之处在于如果得到锁,在当前事务的结束时自动释放,而且不能被显式的释放。只允许sysadmin对键值对(65535, 65535)加事务级别的排他咨询锁,普通用户无权限。
- pg_try_advisory_xact_lock_shared(key bigint)
返回值类型:Boolean
- pg_try_advisory_xact_lock_shared(key1 int, key2 int)
返回值类型:Boolean
备注:pg_try_advisory_xact_lock_shared类似于pg_try_advisory_lock_shared,不同之处在于如果得到锁,在当前事务结束时自动释放,而且不能被显式的释放。
- lock_cluster_ddl()
描述:尝试对数据库内所有存活的数据库主节点获取会话级别的排他咨询锁。
返回值类型:Boolean
备注:只允许sysadmin调用,普通用户无权限。
- unlock_cluster_ddl()
返回值类型:Boolean
- GaussDB培训_GaussDB教程_高斯数据库培训-华为云
- GaussDB数据库函数_GaussDB函数和操作符_高斯数据库函数-华为云
- GaussDB学习_gaussdb教程_高斯数据库学习_华为云
- GaussDB函数_GaussDB数据库函数_高斯数据库函数_华为云
- GaussDB支持的函数_GaussDB函数类型解析_高斯数据库支持的函数-华为云
- GaussDB数据库登录_Gaussdb登录管理控制台_高斯数据库登录-华为云
- GaussDB了解_GaussDB入门_高斯数据库了解_华为云
- GaussDB操作手册_云数据库Gaussdb快速入门_高斯数据库操作手册-华为云
- GaussDB学习_gaussdb数据库_高斯数据库学习_华为云
- GaussDB数据库_金融级高安全_高斯数据库_华为云