TRY_GET_XACT_LOCK
语法:
TRY_GET_XACT_LOCK(name_expr)
功能:TRY_GET_XACT_LOCK(name_expr) 为一个事务尝试获取一把锁名为name_expr的排他咨询锁(exclusive advisory lock),若获取成功返回TRUE,之后另一个事务若也调用TRY_GET_LOCK(name_expr)尝试获取同名锁时,将会立刻返回FALSE,获取同名锁失败,直到该锁释放。
TRY_GET_XACT_LOCK()的返回值如下:
TRUE: 成功获取到锁。
FALSE: 未能获取到锁。
通过TRY_GET_XACT_LOCK(name_expr)获取到的锁可通过以下方式释放:
隐式释放: 事务/会话中断(不论正常或异常)时该事务/会话占有的锁自动释放。
说明:
表示锁名的name_expr的计算结果的字符串长度不能超过64字节。
同一个事务同时多可以加32把锁。
同一事务可以多次对同一个锁名上锁,在事务/会话结束时会主动释放,无需显示释放。对同一锁名多次尝试加锁时,若次加锁成功,则第二次加锁开始的次数并不计入上述所说的32把锁的个数中。
示例:
对表中某一列进行加锁。
--删除表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 TRY_GET_XACT_LOCK('staff_id');
TRY_GET_XACT_LOCK('STAFF_ID')
--------------------
TRUE
1 rows fetched.