首页 > 其他 > 详细

库存扣减的流水账记录问题

时间:2015-03-12 16:43:27      阅读:283      评论:0      收藏:0      [点我收藏+]

场景描述:

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

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

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

问题描述:

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

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

问题分析:

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

解决方案:

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

 

库存扣减的流水账记录问题

原文:http://www.cnblogs.com/firebata/p/4332683.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!