锁函数
TiDB 支持 MySQL 5.7 中的大部分用户级锁函数。
支持的函数
| 函数名 | 功能描述 | 
|---|---|
GET_LOCK(lockName, timeout) | 获取咨询锁。lockName 参数不得超过 64 个字符。在超时前,TiDB 最长等待 timeout 秒并返回失败。 | 
RELEASE_LOCK(lockName) | 释放先前获取的锁。lockName 参数不得超过 64 个字符。 | 
RELEASE_ALL_LOCKS() | 释放当前会话持有的所有锁。 | 
MySQL 兼容性
- TiDB 允许的最短超时时间为 1 秒,最长超时时间为 1 小时(即 3600 秒)。而 MySQL 允许最短 0 秒和最长无限超时(
timeout=-1)。TiDB 会自动将超出范围的值转换为最接近的允许值,timeout=-1会被转换为 3600 秒。 - TiDB 不会自动检测用户级锁导致的死锁。死锁会话将在 1 小时内超时,但你也可以在任一受影响的会话上使用 
KILL语句手动终止死锁。你还可以通过始终用相同顺序获取用户级锁的方法来防止死锁。 - 在 TiDB 中,锁对集群中所有 TiDB 服务器生效。而在 MySQL Cluster 和 Group Replication 中,锁只对本地单个服务器生效。
 
不支持的函数
IS_FREE_LOCK()IS_USED_LOCK()