我如何计算每个客户的订单数量
我有两个表格为客户$ 和订单$ (我不确定为什么在表名称之后有一个$符号。它显示在我的Microsoft SQL Server Management Studio中时间我导入Excel文件)。
客户$表有2列= name(nvarchar(255,null)| customer_id(float,null)
订单$ table有4列= order_id(nvarchar(255,null)| customer_id | status(nvarchar(255,null) (dateTime,null)
我的陈述是计算每个客户的订单数
SELECT c.name,c.customer_id AS CustomerID,o.customer_id AS OcustomerID, COUNT(*) AS Number_of_orders
FROM customers$ c, orders$ o
WHERE c.customer_id = o.customer_id
GROUP BY name
ORDER BY Number_of_orders
输出: MSG 8120,16级,状态1,第1行 列“客户$ ..customer_id”在选择列表中无效,因为它不包含在汇总函数中,或按子句中的组中包含。
I have two TABLES as customers$ and orders$ (I am not sure why there is a $ sign after the table name. It appears in my Microsoft SQL Server Management Studio every time I import the excel file).
customer$ table has 2 columns = name(nvarchar(255,null) | customer_id(float,null)
orders$ table has 4 columns = order_id(nvarchar(255,null) | customer_id | status(nvarchar(255,null) | order_date(datetime, null)
My statement is to count the number of orders per customer
SELECT c.name,c.customer_id AS CustomerID,o.customer_id AS OcustomerID, COUNT(*) AS Number_of_orders
FROM customers$ c, orders$ o
WHERE c.customer_id = o.customer_id
GROUP BY name
ORDER BY Number_of_orders
OUTPUT:
Msg 8120, Level 16, State 1, Line 1
Column 'customers$.customer_id' is invalid in the select list because it is not contained in either an aggregate function or the GROUP BY clause.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
当您使用聚合函数(例如
COUNT
、SUM
、AVG
等)时,任何未聚合的字段都必须列在GROUP BY
子句:您也不需要
o.customer_id
。连接条件确保c.customer_id
和o.customer_id
相同。另外,请避免使用旧的连接语法:
将其替换为 INNER JOIN :
When you use an aggregate function (like
COUNT
,SUM
,AVG
, etc.), any field that is not aggregated must be listed in theGROUP BY
clause:You also don't need
o.customer_id
. The join condition make sure thatc.customer_id
ando.customer_id
are identical.Also, avoid the old join syntax:
Replace it with
INNER JOIN
:您可能想进行在线选择
,或者需要添加C.customer_id。选择o.customer_id也没有意义,因为这应该与C.customer_id相同
You probably want to do either an in-line select
or you need to add c.customer_id to your Group By. Also no point in selecting o.Customer_id as that should be identical to c.customer_id