如何修復 MySQL 錯誤 1111:按列分組時組函數的無效使用?

DDD
發布: 2024-10-24 12:15:01
原創
808 人瀏覽過

How to Fix MySQL Error 1111: Invalid Use of Group Function When Grouping By a Column?

解決MySQL 錯誤1111:無效使用群組函數

使用MySQL 時,您可能會遇到錯誤「Error 1111 (HY000) :嘗試使用群組函數(例如COUNT(*))聚合數據,同時按列分組時,群組函數使用無效」。

要解決此錯誤,請避免在執行 SELECT 子句時在 SELECT 子句中使用群組函數GROUP BY 操作。相反,請使用子查詢或 ORDER BY 子句來擷取所需的最大值。

請考慮以下範例:

<code class="mysql">SELECT
    name,
    MAX(COUNT(*)) AS max_count
FROM table
GROUP BY name;</code>
登入後複製

此查詢將傳回錯誤,因為 COUNT()在 SELECT 子句中使用,同時也依名稱分組。要解決此問題,請從SELECT 子句中刪除COUNT() 並將其用作MAX 函數內的子查詢:

<code class="mysql">SELECT
    MAX((SELECT COUNT(*) FROM table WHERE name = t.name)) AS max_count
FROM table t
GROUP BY name;</code>
登入後複製

執行此查詢後,您將獲得每個的最大記錄數表中的名稱。或者,您可以使用 ORDER BY 子句按計數對結果進行排序,然後只取得第一筆記錄:

<code class="mysql">SELECT
    name,
    COUNT(*) AS count
FROM table
GROUP BY name
ORDER BY count DESC
LIMIT 1;</code>
登入後複製

以上是如何修復 MySQL 錯誤 1111:按列分組時組函數的無效使用?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!