Mysql 5.7以上版本Group By异常

本文解析了Mysql5.7以上版本中GroupBy语句的异常情况,详细介绍了ONLY_FULL_GROUP_BY模式下,如何避免因非聚合字段未出现在GROUP BY子句中而导致的错误。并提供了调整sql_mode的方法,以确保查询的正常执行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Mysql 5.7以上版本Group By异常

原文地址

在运行group by语句时,出现以下错误:

ERROR 1055 (42000): Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'xxx.xxx.room_id' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

这是由于sql_mode中设置了ONLY_FULL_GROUP_BY

ONLY_FULL_GROUP_BY:此模式下,GROUP BY 语句只能查询GROUP BY 后出现的字段以及聚合函数。

例如以下sql在这种模式下可以正常执行:

    SELECT
    	room_id AS roomId,
    	SUM( use_data ) AS useData,
    	SUM( price ) AS price 
    FROM
    	cost_record 
    GROUP BY
    	room_id

以下sql在这种模式下无法正常执行,并会报错:

    SELECT
    	room_id AS roomId,
    	room_name AS roomName,
    	SUM( use_data ) AS useData,
    	SUM( price ) AS price 
    FROM
    	cost_record 
    GROUP BY
    	room_id

room_name 字段没有在 GROUP BY 后,也不是一个聚合函数,所以会报错。

一般情况下,我们都会按照第二种来查询数据,如果要能正常执行,修改一下sql_mode,去掉ONLY_FULL_GROUP_BY就可以了:

  1. 查询sql_mode
select @@sql_mode;
ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
  1. 更新sql_mode
SET GLOBAL sql_mode='STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION'
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值