记录:解决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
sql_mode = "STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION"

然后重启下 MySQL 即可。
注意:不要添加到 my.cnf 配置文件中的最底部,那样会不生效的,具体原因未知,放到 [mysqld] 下面即可。
您可能感兴趣的文章
- 12-31hiredis从安装到项目实战操作
- 12-31phpmyadmin登录时怎么指定服务器ip和端口
- 12-31MySQL线上死锁分析实战
- 12-31MySQL 触发器的使用和理解
- 12-31MySQL 字段默认值该如何设置
- 12-31Redis主从同步配置的方法步骤(图文)
- 12-31MySQL 字符串拆分操作(含分隔符的字符串截取)
- 12-31redis 交集、并集、差集的具体使用
- 12-31MySQL精讲之二:DML数据操作语句
- 12-31PostgreSQL判断字符串是否包含目标字符串的多种方法


阅读排行
推荐教程
- 12-23PL/SQL登录Oracle数据库报错ORA-12154:TNS:无法解析指定的连接标识符
- 12-23使用imp和exp命令对Oracle数据库进行导入导出操作详解
- 12-11mysql代码执行结构实例分析【顺序、分支、循环结构】
- 12-08添加mysql的用户名和密码是什么语句?
- 12-05mysql的事务,隔离级别和锁用法实例分析
- 12-23详解Oracle游标的简易用法
- 12-20PhpMyAdmin出现错误数据无法导出怎么办?
- 12-19Redis中实现查找某个值的范围
- 12-15浅析mysql迁移到clickhouse的5种方法
- 12-15CentOS7 64位下MySQL5.7安装与配置教程




