session A session Bmysql_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 对其他事务有用,但是对自己多次提交就不起作用?
$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 对其他事务有用,但是对自己多次提交就不起作用?
一个SESSION获取到X锁后,你可以随便怎么操作,只要不释放。