SELECT
供应商代码 = vv.vend_id
,供应商名称 = max(vv.vend_name)
,产品代码 = pp.prod_id
,产品名称 = max(pp.prod_name),
订单数量 = sum(dd.quantity)
,订单价格 = sum(dd.item_price)
,订单金额 = sum(dd.quantity*dd.item_price)
,采购数量 = (case WHEN order_TYPE='IMP' THEN SUM(DD.QUANTITY) ELSE 0 END)
,采购单价 = (case WHEN order_TYPE='IMP' THEN SUM(item_price)ELSE 0 END)
,采购金额 = (case WHEN order_TYPE='IMP' THEN SUM(item_price)ELSE 0 END)*(case WHEN order_TYPE='IMP' THEN SUM(DD.QUANTITY) ELSE 0 END)
,销售数量 = (case WHEN order_TYPE='EXP' THEN SUM(DD.QUANTITY) ELSE 0 END)
,销售价格 = (case WHEN order_TYPE='exp' THEN SUM(item_price)ELSE 0 END)
,销售金额 = (case WHEN order_TYPE='EXP' THEN SUM(DD.QUANTITY) ELSE 0 END)*(case WHEN order_TYPE='exp' THEN SUM(item_price)ELSE 0 END)
,库存数量 = (case WHEN order_TYPE='IMP' THEN SUM(DD.QUANTITY) ELSE 0 END)-(case WHEN order_TYPE='EXP' THEN SUM(DD.QUANTITY) ELSE 0 END)
,库存余额 = ((case WHEN order_TYPE='IMP' THEN SUM(DD.QUANTITY) ELSE 0 END)-(case WHEN order_TYPE='EXP' THEN SUM(DD.QUANTITY) ELSE 0 END))*(case WHEN order_TYPE='IMP' THEN SUM(item_price)ELSE 0 END)
FROM Vendors vv
LEFT JOIN Products pp ON pp.vend_id=vv.vend_id
LEFT JOIN OrderItems dd ON dd.prod_id=pp.prod_id
LEFT JOIN Orders ON dd.order_num=Orders.order_num
LEFT JOIN Customers ON Orders.cust_id=Customers.cust_id
WHERE vv.vend_id='DLL01'
GROUP BY vv.vend_id ,pp.prod_id ,order_TYPE
结果如下
我要把里面的0都去掉,合并成四行,该怎么做,求大佬解答!
这是原表
您好,主要问题在于分组,仔细核实一下分组。
GROUP BY pp.prod_id ,order_TYPE
GROUP BY pp.prod_id ,order_TYPE
试一下这个分组是不是你想要的效果
不行啊,必须把 order_TYPE去掉才能只有四行,加了 order_TYPE就有8行,但order_TYPE又必须用到, 这该怎么处理呢
您好,如有疑问可以给我留言
您好,订单类型order_TYPE,说明有八种订单类型,八种订单类型不是一样的