MySQL提示sql_mode=only_full_group_by解决办法

MySQL异常sql_mode=only_full_group_by

原因:在MySQL 5.7后MySQL默认开启了SQL_MODE严格模式,对数据进行严格校验。
会报sql_mode=only_full_group_by错误说明写的SQL语句不严谨,
对于group by聚合操作,select中的列只能是出现在group by中的列,使用聚合函数除外,如max()、min()等

如以下例子会报错:

改成下面的SQL则不报错:

解决这个问题可以有三个方法:

方法一:
使用 group_concat() 或 any_value()
group_concat():将分到同一组的数据默认用逗号隔开作为返回数据
any_value():将分到同一组的数据里第一条数据的指定列值作为返回数据

修改后语句如下:

方法二:
如果语句太多,变动太大,可以改数据库配置

首先查看当前 sql_mode

可以看到返回以下值:

重新设置,去掉ONLY_FULL_GROUP_BY即可:

当然,如果想去掉所有限制也是可以的:

这个方法的好处是不用重启MySQL生效(需要注意的是在当前会话实例中是不生效的),坏处是重启后会恢复原样。

方法三:
永久生效,修改配置文件my.ini

在[mysqld]模块下新增一行配置:

保存,重启后生效。

Original: https://www.cnblogs.com/woods1815/p/16684345.html
Author: 幽篁晓筑
Title: MySQL提示sql_mode=only_full_group_by解决办法

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/611961/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球