zoukankan      html  css  js  c++  java
  • django 订单并发修改库存乐观悲观锁

    在多个用户同时发起对同一个商品的下单请求时,先查询商品库存,再修改商品库存,会出现资源竞争问题,导致库存的最终结果出现异常。

    解决办法:
    悲观锁

    当查询某条记录时,即让数据库为该记录加锁,锁住记录后别人无法操作,使用类似如下语法

    select stock from tb_sku where id=1 for update;

    SKU.objects.select_for_update().get(id=1)


    悲观锁类似于我们在多线程资源竞争时添加的互斥锁,容易出现死锁现象,采用不多。

    乐观锁

    乐观锁并不是真实存在的锁,而是在更新的时候判断此时的库存是否是之前查询出的库存,如果相同,表示没人修改,可以更新库存,否则表示别人抢过资源,不再执行库存更新。类似如下操作

    update tb_sku set stock=2 where id=1 and stock=7;

    SKU.objects.filter(id=1, stock=7).update(stock=2)

  • 相关阅读:
    springboot maven打包插件
    maven打包指定main入口插件
    团队开发环境一致性性要求
    springboot 在idea中实现热部署
    IDEA 2018.1可用License服务(持续更新)
    IDEA打jar包
    3月18号
    3月17号
    3月16号
    3月13号
  • 原文地址:https://www.cnblogs.com/SunshineKimi/p/15512442.html
Copyright © 2011-2022 走看看