商品订单问题处理

1.商品订单涉及到多张表修改,所以关于订单整个sql操作是在事务层面进行处理;

2.有个问题在于订单高并发的情况下,你先查询库存,再减库存的话,可能你查库存的时候别人已经减了库存,数据会有错误。

此时解决方案有三种:1.对于查询库存再减库存的操作应该在代码上加个线程锁;2.使用任务队列celery执行串行任务,启动只有一个进程的celery,让订单一个一个进行处理;3.使用乐观锁,在更新的时候判断此时的库存是否是之前查询出的库存,如果相同,表示没人修改,可以更新库存,否则表示别人抢过资源,不再执行库存更新,这句sql不执行的话整个事务就会回滚,下单失败。不会导致数据错误。

update tb_sku set stock=2 where id=1 and stock=7;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值