zoukankan      html  css  js  c++  java
  • 库存扣减的流水账记录问题

    场景描述:

            商品都有库存数,每卖出N件,就会将库存减N。系统在这个过程做了两件事情:

            1,扣库存前,先将该商品的当前库存数从“商品库存表”中查出来,记录流水账信息到“库存扣减流水表”中,包括该商品的当前库存、扣减数量、扣减后的库存。

            2,扣减库存,更新库存表的商品库存数。

    问题描述:

            在单线程下没有问题,但是在多线程并发卖同一个商品的时候,出现了问题:

            存库表的存库是正确的,也是就是说现有系统的隔离级别,防止了在多线程下扣减库存错误();但是记录库存扣减流水信息时,    出现了两个线程的读取到的当前库存数一样,期望的结果是:当前线程读取到的库存数必须是上一个线程扣减库存后的库存。

    问题分析:

            库存是当前线程,读取到内存中的,依次记录流水,扣减存库。所以当前线程必须等到上个线程事务提交后,扣减库存更新到数据库后,才能去库存表中查出库存数。

    解决方案:

            在查询库存的SQL语句后增加for update,锁定当前记录;后来的线程,执行该语句时,将处于阻塞状态,只有等待前面的线程事务提交后,后来的线程的查询语句才会有返回结果。这时返回的库存已是最新的库存。

  • 相关阅读:
    JSON序列化选项
    JOSN的stringify()和parse()方法
    html5增强元素--续
    html5页面增强元素
    js继承模式
    js常用设计模式
    js跨浏览器事件处理
    前端兴趣浓厚,后端提不起来兴趣
    padding的讲究
    margin的讲究
  • 原文地址:https://www.cnblogs.com/firebata/p/4332683.html
Copyright © 2011-2022 走看看