多并发下人数统计的代码陷阱

在我们的电商系统中,有一个表存放商品的总量iNum1和已经购买量iNum2(或者剩余量)。

当用户购买了一个商品,我们后台的业务逻辑原来是这样处理的:

根据ID获取商品对像

Product product = commonService.getProductById(productId);

根据对象得到剩余量

buiedNum = product.getNum2();

剩余量加1

buiedNum--;

然后更新数据到新的剩余量

update table set iNum2=buiedNum。

在单用户操作的情况下这样没有问题,如果是多用户并发,第一个用户获取到剩余量和第二个用户获取到的剩余量是一样的(数据库事务采用默认模式),假设都是100,那么2个用户操作之后,新的剩余量都是99,数据库里面的剩余量会更新为99.导致有一个用户的购买行为没有记录到剩余量里面。商品中记录的数据和实际卖出的数据不一致,导致商品会有超卖的情况。

因此,在多用户并发的情况下不能把剩余量、已卖出量等数字作为中间数据存起来进行数学运算。

而直接采用在sql里面进行数字运算,以上例,最终更新数据的sql为:

update table set iNum2=iNum2-1 where id=XXX and iNum2>0

如果执行的影响结果为0,则表示已经超卖,事务回滚。


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值