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