MySQL连接查询综合运用
综合使用连接查询、聚合函数和分组查询可以实现很多复杂的查询需求
看看以下的案例吧
- 案例1:统计每件商品的销售数量和销售金额,要求按照销售量和销售金额升序显示商品名、销售量和销售金额
- 代码如下:
SELECT g.goodsName,SUM(od.quantity),SUM(od.quantity*g.unitPrice)
FROM goods g LEFT JOIN ordersdetail od ON g.goodsID=od.goodsID
GROUP BY g.goodsID
ORDER BY SUM(od.quantity),SUM(od.quantity*g.unitPrice);
-
运行结果如下:
-
案例2:计算每个订单的金额,要求按照订单下单日期升序和订单金额降序显示订单ID、订单下单日期、订单金额和顾客姓名。
-
代码如下:
SELECT o.ordersID,o.deliveryDate,SUM( od.quantity*g.unitPrice),c.cName
FROM orders o,ordersdetail od,goods g,customer c
WHERE o.ordersID=od.ordersID AND od.goodsID=g.goodsID AND o.customerID=c.customerID
GROUP BY o.ordersID
ORDER BY o.deliveryDate,SUM( od.quantity*g.unitPrice) DESC;
———————————————————————————————
总结:
1.连接查询综合应用要熟练运用SELECT语句以及WHERE、GROUP BY 、 ORDER BY语句的使用,组合一起使用解决问题。
2.完成查询的解决思路不只一种,需要多多练习就能够很好的去使用查询啦~