乐观锁减库存遇到的一些问题,一级缓存,隔离级别,库存少了

为了方便操作数据库用的是JPA

第一个坑:JPA的一级缓存,导致查询死循环

代码:

@RestController
public class GoodsController {
   
    @Autowired
    GoodsDao goodsDao;
    
    /**
     * 减库存
     * @param id
     * @return
     */
    @Transactional
    @GetMapping("/stock")
    public String stock(Integer id)  {
   
        Optional<Goods> goodsOptional = goodsDao.findById(id);
        int stock = goodsOptional.get().getStock();

        if (stock <= 0) {
   
            return "卖完了";
        }

       System.out.println("库存="+stock);
        //为了演示遇到的第一个坑,后续会去掉
        try {
   
            Thread.sleep(2000);
        } catch (InterruptedException e) {
   
            e.printStackTrace();
        }

        Integer result = goodsDao.updateStockById(stock - 1, stock, id);
        if (result == 0) {
   
            stock(id);
        }

        return "成功";
    }

    /**
     * 库存 -1 
     * @param id
     * @return
     */
    @Transactional
    @GetMapping("/reduce_stock")
    public String reduce_stock(Integer id) {
   
         Optional<Goods> goodsOptional = goodsDao.findById(id);
        Goods goods = goodsOptional.get();
        int stock = goods.getStock();

        goods.setStock(stock-1);
        goods= goodsDao.save(goods);
        System.out.println("库存成功减 1 数据库的库存为"+goods.getStock());

        return "成功";
    }

}

-----------------------------------------------------------
Dao的代码:
public interface GoodsDao  extends JpaRepository<Goods,Integer>, JpaSpecificationExecutor<Goods> {
   
    @Transactional
    @Query(value = "update goods  set stock=?1  where stock=?2 and id=?3 ", nativeQuery = true)
    @Modifying
    Integer updateStockById(Integer stock,Integer old_stock , Integer id);
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值