msyql get_lock()与RELEASE_LOCK()

<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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值