用sql语句处理下列问题,求大佬解答!!

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,说明有八种订单类型,八种订单类型不是一样的