MySQL 加锁与解锁函数整理笔记
目录
[MySQL 加锁与解锁函数](#MySQL 加锁与解锁函数)
MySQL 加锁与解锁函数
MySQL中提供了对数据进行加锁和解锁的函数,包括GET_LOCK、RELEASE_LOCK、IS_FREE_LOCK 和 IS_USED_LOCK 函数。
GET_LOCK
GET_LOCK(value,timeout) 函数使用字符串value给定的名字获取锁,持续timeout秒。
如果成功获取锁,则返回1,如果获取锁超时,则返回0,如果发生错误,则返回NULL。
使用GET_LOCK(value,timeout)函数获取的锁,当执行RELEASE_LOCK(value)或断开数据库连接(包括正常断开和非正常断开),锁都会被解除。
使用示例如下:
bash
mysql> SELECT GET_LOCK('goodid_1',500);
+--------------------------+
| GET_LOCK('goodid_1',500) |
+--------------------------+
| 1 |
+--------------------------+
1 row in set
获得一个名称为goodid_1,持续时间为500s的锁。
RELEASE_LOCK
RELEASE_LOCK(value) 函数将以value命名的锁解除。
如果解除成功,则返回1,如果线程还没有创建锁,则返回0,
如果以value命名的锁不存在,则返回NULL。
使用示例如下:
bash
mysql> SELECT RELEASE_LOCK('goodid_1');
+--------------------------+
| RELEASE_LOCK('goodid_1') |
+--------------------------+
| 1 |
+--------------------------+
1 row in set
mysql> SELECT RELEASE_LOCK('goodid_1');
+--------------------------+
| RELEASE_LOCK('goodid_1') |
+--------------------------+
| NULL |
+--------------------------+
1 row in set
注意:锁不存在包括两种情况。
• 从未被GET_LOCK(value,timeout)函数获取过。
• 锁已经被调用RELEASE_LOCK(value)函数释放过。
IS_FREE_LOCK
IS_FREE_LOCK(value) 函数判断以value命名的锁是否可以被使用。
如果可以被使用,则返回1,如果不能使用,也就是说正在被使用,则返回0,
如果发生错误,则返回NULL。
使用示例如下:
bash
mysql> SELECT IS_FREE_LOCK('goodid_1');
+--------------------------+
| IS_FREE_LOCK('goodid_1') |
+--------------------------+
| 1 |
+--------------------------+
1 row in set
mysql> SELECT GET_LOCK('goodid_1',500);
+--------------------------+
| GET_LOCK('goodid_1',500) |
+--------------------------+
| 1 |
+--------------------------+
1 row in set
mysql> SELECT IS_FREE_LOCK('goodid_1');
+--------------------------+
| IS_FREE_LOCK('goodid_1') |
+--------------------------+
| 0 |
+--------------------------+
1 row in set
IS_USED_LOCK
IS_USED_LOCK(value) 函数判断以value命名的锁是否正在被使用,
如果正在被使用,则返回使用该锁的数据库连接ID,否则返回NULL。
使用示例如下:
bash
mysql> SELECT IS_USED_LOCK('goodid_1'), IS_USED_LOCK('test');
+--------------------------+----------------------+
| IS_USED_LOCK('goodid_1') | IS_USED_LOCK('test') |
+--------------------------+----------------------+
| 28 | NULL |
+--------------------------+----------------------+
1 row in set
总结
MySQL 加锁与解锁函数整理笔记