因为双十一购买了新的服务器,配置从原先的1C1G1M,升级到现在的2C4G5M,所以在搬家后也用上了更高版本的环境:

Linux 7.6 64位

Nginx 1.16.1

PHP 7.3.1

MySQL 8.0

也正因为高版本的MySQL原因,对于使用 GROUP BY 会导致出现 SELECT list is not in GROUP BY clause and contains nonaggregated 问题。


记录:解决MySQL5.7以上group by报错的问题 MySQL 第1张


原因是:对于 GROUP BY 聚合操作,如果在 SELECT 中的列,没有在 GROUP BY 中出现,那么这个 SQL 是不合法的,因为列不在 GROUP BY 从句中,也就是说查出来的列必须在 GROUP BY 后面出现否则就会报错,或者这个字段出现在聚合函数里面。

这时候可以登录数据库,查看当前的 sql_mode 模式:


记录:解决MySQL5.7以上group by报错的问题 MySQL 第2张


把 ONLY_FULL_GROUP_BY 删掉,其它的复制出来,找到数据库配置文件 my.cnf ,在里面的 [mysqld] 中添加:

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


记录:解决MySQL5.7以上group by报错的问题 MySQL 第3张


然后重启下 MySQL 即可。


注意:不要添加到 my.cnf 配置文件中的最底部,那样会不生效的,具体原因未知,放到 [mysqld] 下面即可。