最近碰到mysql覆盖写的低概率问题

     最近碰到一个低概率问题:

     10

     加40

     加60

     预期结果是110, 但最终实际结果是50

    

    单机单进程场景,来看下:


func proc() {
	
	amount := queryAmountFromDb()

	begin lock
	   begin transaction
	       amount += req.OrderAmount
	       setToDb(amount)
	   end transaction
	end lock

}

      平常没问题,但是,当两个请求并发而来时, 就有问题了------典型的覆盖写问题。 改成如下即可:


func proc() {
	
	begin lock
	   begin transaction
	   	   amount := queryAmountFromDb()
	       amount += req.OrderAmount
	       setToDb(amount)
	   end transaction
	end lock

}

      搞定, 不多说。

 

     补充: 后来又遇到过一次100-40-60=40的问题, 哈哈。

 

 

 

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值