关于mysql innodb 行锁
时间:2011-05-31
来源:互联网
             session A session B
mysql_query("begin");
$a=mysql_fetch_assoc(mysql_query("select * from abc where id=1 for update"));
if($a['qty']>0){
mysql_query("update abc set qty=qty-1 where id=1");
}
mysql_query("commit");
如果session A 和 session B 同时执行就没有问题(A浏览器和B浏览器同时执行)
由于网速慢,多次提交session A就会出现负数(用A浏览器),是否for update 对其他事务有用,但是对自己多次提交就不起作用?
            mysql_query("begin");
$a=mysql_fetch_assoc(mysql_query("select * from abc where id=1 for update"));
if($a['qty']>0){
mysql_query("update abc set qty=qty-1 where id=1");
}
mysql_query("commit");
如果session A 和 session B 同时执行就没有问题(A浏览器和B浏览器同时执行)
由于网速慢,多次提交session A就会出现负数(用A浏览器),是否for update 对其他事务有用,但是对自己多次提交就不起作用?
作者: jakjakgogogo 发布时间: 2011-05-31
             是的。
一个SESSION获取到X锁后,你可以随便怎么操作,只要不释放。
            一个SESSION获取到X锁后,你可以随便怎么操作,只要不释放。
作者: zuoxingyu 发布时间: 2011-05-31
             关键在于你是用的网页。 网页并不会保持连接,也就是当然点一个页面,当这个请求发到HTTP服务器端,后服务器开始执行你的PHP代码。当PHP代码完成并传送HTML代码到你的浏览器,则PHP就结束了。数据库SESSION也就释放了 也谈不上加锁了。            
            作者: ACMAIN_CHM 发布时间: 2011-05-31
 相关阅读 更多  
      
    热门阅读
-  
 office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
          阅读:74
 -  
 如何安装mysql8.0
          阅读:31
 -  
 Word快速设置标题样式步骤详解
          阅读:28
 -  
 20+道必知必会的Vue面试题(附答案解析)
          阅读:37
 -  
 HTML如何制作表单
          阅读:22
 -  
 百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
          阅读:31
 -  
 ET文件格式和XLS格式文件之间如何转化?
          阅读:24
 -  
 react和vue的区别及优缺点是什么
          阅读:121
 -  
 支付宝人脸识别如何关闭?
          阅读:21
 -  
 腾讯微云怎么修改照片或视频备份路径?
          阅读:28
 















