Heim >Backend-Entwicklung >PHP-Tutorial >用了数据库事务,并发状态下还是出现记录为负值
比如秒杀某个奖品,奖品数量为1 ,5 个人同时请求, 有一个请求成功后,把数据库值更改为0,接着进行其他后续操作, 然后提交事务,其他4个请求时会提示精品已发完
代码
<?php mysql_query('START TRANSACTION') if(奖品数量 <=0){ 提交事务 return ; } 奖品数量-1; * 其它后续操作 xxx xxxx ....... 提交事务 mysql_query('COMMIT')?>
mysql 是默认自动提交事务的,即每条 sql 指令都 COMMIT
你需要主动的关闭这一行为
事务处理时,相关的 sql 指令被隔离在一个副本中,所以是相对独立的
但这并不意味其他的连接不能做数据操作
所以,事务只能保证本次链接中的操作的完备性,并不能控制其他连接的操作
事务开始计数器减一如果计数器为负:回滚,退出其他操作提交
计数器减一如果计数器为负:计数器加一,退出其他操作
mysql 是默认自动提交事务的,即每条 sql 指令都 COMMIT
你需要主动的关闭这一行为
事务处理时,相关的 sql 指令被隔离在一个副本中,所以是相对独立的
但这并不意味其他的连接不能做数据操作
所以,事务只能保证本次链接中的操作的完备性,并不能控制其他连接的操作
事务开始计数器减一如果计数器为负:回滚,退出其他操作提交
计数器减一如果计数器为负:计数器加一,退出其他操作
是的,但你是这么描述的
if(奖品数量 提交事务
return ;
}
奖品数量-1;
* 其它后续操作
奖品数量-1; 后你并没有说要判定他的合法性
是的,但你是这么描述的
if(奖品数量 提交事务
return ;
}
奖品数量-1;
* 其它后续操作
奖品数量-1; 后你并没有说要判定他的合法性
奖品数量-1 要真实发生后,才可以判断是否小于0
update tbl_name set prize=prize-1
select prize from tbl_name
if prize ROOLBACK
endif
奖品数量-1 要真实发生后,才可以判断是否小于0
update tbl_name set prize=prize-1
select prize from tbl_name
if prize ROOLBACK
endif