理解 SQL 中的“Not a Single-Group Group Function”错误
尝试将组函数与 SELECT 中的各个列表达式组合时语句,如提供的查询中所示:
SELECT SSN, MAX(SUM(TIME)) FROM downloads GROUP BY SSN
您可能会遇到“不是单组组函数” 错误。出现这种情况是因为 SUM(TIME) 组函数为每个组 (SSN) 计算单个值,从而使其与单个列表达式 SSN 不兼容。
要解决此错误,您有多种选择:
删除单个列表达式:
SELECT MAX(SUM(TIME)) FROM downloads GROUP BY SSN
这只会返回没有相应 SSN 的最大总和值。
为所有列添加 GROUP BY 子句表达式:
SELECT SSN, MAX(SUM(TIME)) FROM downloads GROUP BY SSN, TIME
这将按两者对结果进行分组SSN 和 TIME,使 MAX(SUM(TIME)) 函数有效。
使用聚合子查询:
SELECT SSN, SUM(TIME) FROM downloads GROUP BY SSN HAVING SUM(TIME) = (SELECT MAX(SUM(TIME)) FROM downloads GROUP BY SSN)
此子查询计算最大总和值并仅选择每个 SSN 的 SUM(TIME) 与该值匹配的行
根据您的具体要求,这些解决方案之一将允许您获得所需的结果,而不会遇到“不是单组组函数”错误。
以上是如何解决SQL中的'Not a Single-Group Group Function”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!