MySQL 排错-解决MySQL非聚合列未包含在GROUP BY子句报错问题

本文详细介绍了如何处理在项目中遇到的SQL错误,重点在于解决‘only_full_group_by’模式下,非聚合列id在GROUP BY子句外的问题。提供了三种方法,包括临时修改sql_mode、启动时指定sql_mode和持久配置my.cnf。适合MySQL开发者解决常见问题。
摘要由CSDN通过智能技术生成

运行一个项目出现tomcat启动不起来的报错,经过日志排查是因为这个sql语句的问题。

"Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'case_table.id' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by"

原因:存在非聚合列 id ,没有包含在GROUP BY子句中。

但是本例中,其它地方需要用到这个id列,不能去掉。

方法1

查询全局sql_mode

SELECT @@GLOBAL.sql_mode;

SET GLOBAL sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';

注意:该方法仅用于临时修改,重启mysql后,以上设置失效。

方法2

启动mysql时,增加sql_model选项,如下:

mysqld --sql_mode="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION" [...其它选项]

方法3:

linux服务下,修改my.conf (Windows下修改my.ini),在[mysqld]节点下,最末尾添加sql_mode配置,如下:

...

[mysqld]

...

sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

[其它节点配置]

...

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值