首页 > 数据库    MySQL日期:2020-02-22 / 来自互联网 / 浏览

因为双十一购买了新的服务器,配置从原先的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
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] 下面即可。

觉得上面的内容有用吗?快来点个赞吧!

点赞() 我要打赏

温馨提示 : 本站内容来自会员投稿以及互联网,所有源码及教程均为作者总结编辑,请大家在使用过程中提前做好备份,以免发生无法预知的错误,源码类教程请勿直接用于生产环境!

 可能感兴趣的文章