【问题标题】:Aggregated error SQL query聚合错误 SQL 查询
【发布时间】:2017-12-13 00:33:56
【问题描述】:
 select 
person.firstname, 
person.lastname, 
sum(order_item.pricecharged) as [sales]
from person cross join order_item
join ORDERS
on ORDERS.EmployeeID = PERSON.PersonID
group by person.firstname

得到一个错误:

消息 8120,第 16 级,状态 1,第 5 行 列“person.LastName”在选择列表中无效,因为它既不包含在聚合函数中,也不包含在 GROUP BY 子句中。

(对 SQL 查询的新手表示歉意)

【问题讨论】:

  • 这在我看来更像 tsql 或 sql-server
  • 您需要将 person.lastname 添加到 group by 列表中。
  • 该错误消息确认它是 T-SQL 所以我将 MySQL 作为标签删除

标签: sql sql-server mysql-management


【解决方案1】:

该错误告诉您出了什么问题 - 您不能在选择列表(特别是 person.lastname)中有一个不在 group by 列表中的列,除非它有一个聚合函数。您说的是按名字分组,然后将姓氏添加到输出中。如果您有 Bob Jones 和 Bob Smith - 两者的销售额将加在一起,但您没有告诉 SQL 如何处理姓氏,所以会出错。

在这种情况下,您可能希望将组行更改为

group by person.firstname, person.lastname

【讨论】:

    【解决方案2】:

    完全按照错误消息告诉您的操作,将所有“非聚合”列放入 group by 子句中:

    SELECT
          person.firstname                         -- this is "non-aggregating"
        , person.lastname                          -- this is "non-aggregating"
        , SUM(order_item.pricecharged) AS [sales]  -- this is "aggregating"
    FROM person
    CROSS JOIN order_item
    JOIN ORDERS ON ORDERS.EmployeeID = PERSON.PersonID
    GROUP BY
          person.firstname
        , person.lastname
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2019-06-13
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多