首頁 >資料庫 >mysql教程 >如何解決 MySQL 錯誤 #1140:混合群組列?

如何解決 MySQL 錯誤 #1140:混合群組列?

Barbara Streisand
Barbara Streisand原創
2024-12-29 16:51:17752瀏覽

How to Resolve MySQL Error #1140: Mixing of GROUP Columns?

MySQL 錯誤#1140:混合GROUP 欄位

當MySQL 查詢將GROUP 函式與非GROUP 函式資料列混合時,會發生此錯誤資料列時,會發生此錯誤資料列時,會發生此錯誤資料列時,會發生此錯誤資料列時,會發生此錯誤資料列時,會發生此錯誤資料列時,會發生此錯誤資料列時,會發生此錯誤資料列時,會發生此錯誤資料列時,會發生此錯誤資料列時,會發生此錯誤資料列時,會發生此錯誤資料列時,會發生此錯誤列表,但沒有GROUP BY 子句。換句話說,它建議某些選定的列應分組在一起,而其他列則不應分組。

考慮以下 SQL 查詢:

SELECT COUNT(node.nid),
       node.nid AS nid,
       node_data_field_update_date.field_update_date_value AS node_data_field_update_date_field_update_date_value
FROM node node
LEFT JOIN content_type_update node_data_field_update_date ON node.vid = node_data_field_update_date.vid
WHERE node.type IN ('update')
ORDER BY node_data_field_update_date_field_update_date_value DESC;

此查詢正在嘗試對類型「update」的節點數量,並擷取每個節點的節點 ID (nid) 和更新日期。但是,它將 GROUP 函數 COUNT() 與 SELECT 清單中的非 GROUP 欄位 nid 和 node_data_field_update_date_field_update_date_value 混合在一起。

要解決此錯誤,請停用 MySQL 伺服器上的 ONLY_FULL_GROUP_BY 設定或修改查詢以進行分組非團體列:

停用ONLY_FULL_GROUP_BY:

mysql> SET GLOBAL ONLY_FULL_GROUP_BY = OFF;

將分組新增分組:

SELECT COUNT(node.nid) AS node_count,
       node.nid AS nid,
       node_data_field_update_date.field_update_date_value AS node_data_field_update_date_field_update_date_value
FROM node node
LEFT JOIN content_type_update node_data_field_update_date ON node.vid = node_data_field_update_date.vid
WHERE node.type IN ('update')
GROUP BY node.nid, node_data_field_update_date.field_update_date_value
ORDER BY node_data_field_update_date_field_update_date_value DESC;

以上是如何解決 MySQL 錯誤 #1140:混合群組列?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn