程序问答   发布时间:2022-06-02  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了SQL查询,用于统计每个客户的订单数和总金额大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决SQL查询,用于统计每个客户的订单数和总金额?

开发过程中遇到SQL查询,用于统计每个客户的订单数和总金额的问题如何解决?下面主要结合日常开发的经验,给出你关于SQL查询,用于统计每个客户的订单数和总金额的解决方法建议,希望对你解决SQL查询,用于统计每个客户的订单数和总金额有所启发或帮助;

您将COUNT(disTinCT ...)在其他sql引擎中使用:@H_404_3@

SELECT CID, 
       Count(disTinCT o.orderID) AS @R_936_10586@lorders, 
       Sum(OI.Quantity*OI.SALEPricE) AS @R_936_10586@lDollaramount 
FROM [Order] O
INNER JOIN [OrderItem] OI
  ON o.orderID = OI.orderID
GROUP BY CID 
Order BY Count(disTinCT o.orderID) DESC

不幸的是,哪个Access不支持。相反,您可以先获取订单金额,然后在确定订单数量之前将它们加入:@H_404_3@

SELECT CID,
       COUNT(orders.orderID) AS @R_936_10586@lorders,
       SUM(Orderamounts.Dollaramount) AS @R_936_10586@lDollaramount
FROM [orders]
INNER JOIN (SELECT OrderID, Sum(Quantity*SALEPricE) AS Dollaramount 
      FROM OrderItems GROUP BY OrderID) AS Orderamounts
  ON orders.orderID = Orderamounts.OrderID
GROUP BY CID
ORDER BY Count(orders.orderID) DESC

如果您需要包括订单中没有商品的客户(非正常但可能),请更改INNER JOINleft OUTER JOIN。@H_404_3@

解决方法

我有两个 Order带有列的表:

OrderID,OrderDate,CID,employeEID

OrderItem带有列:

OrderID,ItemID,Quantity,SALEPrice

我需要返回CustomerID(CID),每个客户的订单数以及所有订单的每个客户的总金额。

到目前为止,我有两个单独的查询。一个给了我客户订单的数量。

SELECT CID,Count(Order.orderID) AS @R_936_10586@lorders
FROM [Order]
Where CID = CID 
GROUP BY CID
Order BY Count(Order.orderID) DESc;

另一个给了我总销售额。我在合并它们时遇到了麻烦&Hellip;

SELECT CID,Sum(OrderItem.Quantity*OrderItem.SALEPricE) AS @R_936_10586@lDollaramount
FROM OrderItem,[Order]
WHERE OrderItem.OrderID = [Order].orderID
GROUP BY CID

我正在Access 2010中执行此操作。

大佬总结

以上是大佬教程为你收集整理的SQL查询,用于统计每个客户的订单数和总金额全部内容,希望文章能够帮你解决SQL查询,用于统计每个客户的订单数和总金额所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。