记录:解决MySQL5.7以上group by报错的问题
因为双十一购买了新的服务器,配置从原先的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 问题。
原因是:对于 GROUP BY 聚合操作,如果在 SELECT 中的列,没有在 GROUP BY 中出现,那么这个 SQL 是不合法的,因为列不在 GROUP BY 从句中,也就是说查出来的列必须在 GROUP BY 后面出现否则就会报错,或者这个字段出现在聚合函数里面。
这时候可以登录数据库,查看当前的 sql_mode 模式:
把 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"
然后重启下 MySQL 即可。
注意:不要添加到 my.cnf 配置文件中的最底部,那样会不生效的,具体原因未知,放到 [mysqld] 下面即可。