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

分享好友

×
取消 复制
GaussDB T 其他函数GET_SHARED_LOCK
2020-03-06 15:48:17

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的会话级共享咨询锁,无论获取成功或失败都立刻返回结果。

示例:

对表中某一列进行加锁。

--删除表employee。
DROP TABLE IF EXISTS employee;
--创建表employee。
CREATE TABLE employee(staff_id INT NOT NULL, first_name VARCHAR(64));
--**数据。
INSERT INTO employee(staff_id,first_name) values ('1', 'Alice');
INSERT INTO employee(staff_id,first_name) values ('2', 'Jack');
INSERT INTO employee(staff_id,first_name) values ('3', 'Brown');
--提交事务。
COMMIT;
--对'staff_id'列加锁。
SELECT GET_SHARED_LOCK('staff_id',5);

GET_SHARED_LOCK('STAFF_ID',5)
--------------------
TRUE

1 rows fetched.


分享好友

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

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

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

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

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

技术专家

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