iteye_5745 2013-05-21 10:29
浏览 298
已采纳

关于数据查询前插入数据问题

如果有个业务场景:
比如有张库存表 inv,有个字段物料 material,有个字段数量 qty,当然还有ID。
每次入库,先查找库存是否有这个物料,如果有的话,则数量需要加上去,如果不存在,需要生成一条这样的记录,包含物料以及数量。

我只是打个比方,这个在一般系统里面都会初始化的,没个物料都有一条默认的数量为0的记录,我就不说了。

如果不能初始化,我需要动态的添加,则情况如下,比如 M1物料入库10公斤
如果存在 就数量加 不存在就新加一行
if(inv exists 'M1') {
update inv set qty=qty+10 where material='M1'
}else{
insert inv (material,qty) values ('M1',10)
}
如果并发的话,比如 人员A、B同时做入库单
A 执行 查看 exists 时间为t1
B 执行 查看 exists 时间为t2
A 执行 查看 insert 时间为t3
B 执行 查看 insert 时间为t4
t1<t2<t3<t4,如果刚好遇到这样的情况,大家查的时候都不存在,每个人都入了,怎么办,处理这种情况,这样导致物料M1存在2条数据,当然 可以对物料进行唯一索引,但是这样B插入就会报错,请问大家有什么办法让这种情况不发生,不能唯一索引,也不能lock table,谢谢

  • 写回答

2条回答 默认 最新

  • blusewang 2013-05-21 17:57
    关注

    1:必须采用事务,否则会出现丢失更新的情况。
    2:在并发情况下,如何设计这个事务。
    2.1:数据库有默认的锁机制,就像我们执行一条简单的“update table set .... where ...”,数据库会瞬间加排他锁,其它所有的操作等待。
    2.2:数据库加锁时间取决于数据库的设计以及程序处理事务的方法,尽可能的减少事务执行时间。

    3:解决办法
    3.1:开始事务,读加排他锁
    3.2:判断并执行插入或更新操作
    3.3:提交事务

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置