MySQL 错误#1140:了解“GROUP 列的混合”问题
MySQL 错误#1140,“GROUP 列的混合(如果没有 GROUP 列,则 MIN()、MAX()、COUNT()、...) 是非法的当您尝试聚合数据(例如,使用 COUNT() 等函数)而不对结果进行分组时,就会出现“GROUP BY 子句”。当 SQL 查询的 SELECT 子句中包含聚合函数和非聚合列,并且缺少 GROUP BY 子句时,可能会发生这种情况。
问题描述:
The以下 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
使用以下命令执行此查询在服务器上启用 ONLY_FULL_GROUP_BY 设置会导致错误消息:
#1140 - Mixing of GROUP columns (MIN(),MAX(),COUNT(),...) with no GROUP columns is illegal if there is no GROUP BY clause`
解决方案:
要解决此问题,必须禁用 ONLY_FULL_GROUP_BY 设置或强制执行SQL中的分组操作
only_full_group_by = 0
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') GROUP BY node.nid ORDER BY node_data_field_update_date_field_update_date_value DESC
通过应用这些解决方案中的任何一个,您可以绕过“混合组列”错误并成功检索聚合数据。
以上是如何解决 MySQL 错误 #1140:'混合组列”?的详细内容。更多信息请关注PHP中文网其他相关文章!