大前浪 2020-12-15 23:19 采纳率: 0%
浏览 112

如何根据子表状态更新父表状态

假如有订单表(表A),订单货物表(表B),一个订单有多个货物

表A字段:订单ID,状态(未发货、部分发货、已发货)

表B字段:货物ID,所属订单ID,状态(已发货、未发货)

 

现在要更新订单表A:

如果订单下的货物都为“已发货”,则更新订单状态为“已发货”

如果订单下的货物都为“未发货”,则更新订单状态为“未发货”

如果订单下的货物有的“未发货”有的“已发货”,则更新订单状态为“部分发货”

 

如何写语句呢?

  • 写回答

1条回答 默认 最新

  • Keifei 2020-12-16 09:47
    关注
    select 
    a.id,
    case 
    when p.zuida - p.zuixiao = 2 then '部分发货'
    when p.qiuhe > 1 then '已发货'
    when p.qiuhe < -1 then '未发货'
    else '其他'
    end type
    from
    a
    left join 
    (
     select 
     b.id,
     max(case type when '已发货' then 1 else -1 end) zuida,
     min(case type when '已发货' then 1 else -1 end) zuixiao,
     sum(case type when '已发货' then 1 else -1 end) qiuhe
     from
     b
     group by 
     id
    ) p on a.id = p.id
    ;
    
    评论

报告相同问题?

悬赏问题

  • ¥20 指导如何跑通以下两个Github代码
  • ¥15 大家知道这个后备文件怎么删吗,为啥这些文件我只看到一份,没有后备呀
  • ¥15 C++为什么这个代码没报错运行不出来啊
  • ¥15 一道ban了很多东西的pyjail题
  • ¥15 关于#r语言#的问题:如何将生成的四幅图排在一起,且对变量的赋值进行更改,让组合的图漂亮、美观@(相关搜索:森林图)
  • ¥15 C++识别堆叠物体异常
  • ¥15 微软硬件驱动认证账号申请
  • ¥15 GPT写作提示指令词
  • ¥20 根据动态演化博弈支付矩阵完成复制动态方程求解和演化相图分析等
  • ¥15 华为超融合部署环境下RedHat虚拟机分区扩容问题