qq_664231140 2017-09-16 15:24 采纳率: 0%
浏览 928

求一个万能的sql更新语句

 update t_inventory i left join (select entry.id,entry.material m,entry.model model,sum(entry.amount) s from t_sys_sales_slip_entry entry where entry.id in
            <foreach collection="list" item="item" open="(" close=")" separator=",">
                #{item.id}
            </foreach>
         group by entry.material
        ) j on j.m=i.materialid and j.model=i.model set i.qty = (i.qty-j.s)
        where i.materialid in
        <foreach collection="list" item="item" open="(" close=")" separator="," index="i">
            #{item.sysmaterial.id}
        </foreach> and i.model in
        <foreach collection="list" item="item" open="(" close=")" separator=",">
            #{item.model.id}
        </foreach>

这个sql并不是一个万能的sql 存在的缺陷就是 当materialid相同 model不同时 只会更新这个materialid 的一条记录 在materialid相同时 能把in改成=就可以了 吧

请问咋判断 in中产品相同时 用= 不同时用in 呢 ? 或者根本不用这么写 该这么写这条sql

  • 写回答

1条回答 默认 最新

  • devmiao 2017-09-17 02:07
    关注
    评论

报告相同问题?

悬赏问题

  • ¥15 解决一个加好友限制问题 或者有好的方案
  • ¥15 关于#java#的问题,请各位专家解答!
  • ¥15 急matlab编程仿真二阶震荡系统
  • ¥20 TEC-9的数据通路实验
  • ¥15 ue5 .3之前好好的现在只要是激活关卡就会崩溃
  • ¥50 MATLAB实现圆柱体容器内球形颗粒堆积
  • ¥15 python如何将动态的多个子列表,拼接后进行集合的交集
  • ¥20 vitis-ai量化基于pytorch框架下的yolov5模型
  • ¥15 如何实现H5在QQ平台上的二次分享卡片效果?
  • ¥30 求解达问题(有红包)