锁函数
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()