理解 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中文網其他相關文章!