<code class="hljs sql has-numbering"><span class="hljs-operator"><span class="hljs-keyword">select</span> get_lock(<span class="hljs-keyword">key</span>, timeout) </span> <span class="hljs-operator"><span class="hljs-keyword">select</span> release_lock(<span class="hljs-keyword">key</span>)</span></code>
GET_LOCK(name,time)函数定义一个名称为name、持续时间长度为time秒的锁。
- 如果锁定成功,返回1。
- 如果操作超时,返回0。
- 如果发生错误,返回NULL。
(1)get_lock会按照key来加锁,别的客户端再以同样的key加锁时就加不了了,处于等待状态。
(2)当调用release_lock来释放上面加的锁或客户端断线了,上面的锁才会释放,其它的客户端才能进来。
- GET_LOCK('MySQL',10)返回结果为1,说明成功得到了一个名称为'MySQL'的锁,持续时间为10秒。
- IS_USED_LOCK('MySQL')返回结果为当前连接ID,表示名称为'MySQL'的锁正在被使用。
- IS_FREE_LOCK('MySQL')返回结果为0,说明名称为'MySQL'的锁正在被使用。
- RELEASE_LOCK('MySQL')返回值为1,说明解锁成功。
http://blog.csdn.net/tangtong1/article/details/51792617
http://www.baike369.com/content/?id=5677