用了数据库事务,并发状态下还是出现记录为负值
比如秒杀某个奖品,奖品数量为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 指令被隔离在一个副本中,所以是相对独立的
但这并不意味其他的连接不能做数据操作
所以,事务只能保证本次链接中的操作的完备性,并不能控制其他连接的操作
事务开始计数器减一如果计数器为负:回滚,退出其他操作提交
其实用不用事务都一样
计数器减一如果计数器为负:计数器加一,退出其他操作
请问一下这里的计数器说的是 数据库里奖品的数量是吗?
如果是的话
我也是这么判断的
开启事务
如果数量为负数 则回滚退出 否则 数量 -1
其他操作
提交
模拟并发请求我用的是 curl_multi_init 比如数量还剩下1个 模拟请求5次, 数量就变成-4 了
是的,但你是这么描述的
if(奖品数量 提交事务
return ;
}
奖品数量-1;
* 其它后续操作
奖品数量-1; 后你并没有说要判定他的合法性
是的,但你是这么描述的
if(奖品数量 提交事务
return ;
}
奖品数量-1;
* 其它后续操作
奖品数量-1; 后你并没有说要判定他的合法性
这么判断
if(奖品数量-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
谢谢版主耐心的回答,问题解决了,并发的扣减不变成负数了, 原来一直以为 先判断 再减 和 先减再判断效果是一样的

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

长URL(通常用关键字和跟踪参数都混乱)可以阻止访问者。 URL缩短脚本提供了解决方案,创建了简洁的链接,非常适合社交媒体和其他平台。 这些脚本对于单个网站很有价值

在Facebook在2012年通过Facebook备受瞩目的收购之后,Instagram采用了两套API供第三方使用。这些是Instagram Graph API和Instagram Basic Display API。作为开发人员建立一个需要信息的应用程序

Laravel使用其直观的闪存方法简化了处理临时会话数据。这非常适合在您的应用程序中显示简短的消息,警报或通知。 默认情况下,数据仅针对后续请求: $请求 -

这是有关用Laravel后端构建React应用程序的系列的第二个也是最后一部分。在该系列的第一部分中,我们使用Laravel为基本的产品上市应用程序创建了一个RESTFUL API。在本教程中,我们将成为开发人员

Laravel 提供简洁的 HTTP 响应模拟语法,简化了 HTTP 交互测试。这种方法显着减少了代码冗余,同时使您的测试模拟更直观。 基本实现提供了多种响应类型快捷方式: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

PHP客户端URL(curl)扩展是开发人员的强大工具,可以与远程服务器和REST API无缝交互。通过利用Libcurl(备受尊敬的多协议文件传输库),PHP curl促进了有效的执行

您是否想为客户最紧迫的问题提供实时的即时解决方案? 实时聊天使您可以与客户进行实时对话,并立即解决他们的问题。它允许您为您的自定义提供更快的服务

2025年的PHP景观调查调查了当前的PHP发展趋势。 它探讨了框架用法,部署方法和挑战,旨在为开发人员和企业提供见解。 该调查预计现代PHP Versio的增长
