MySQL提示sql_mode=only_full_group_by解决办法

打印 上一主题 下一主题

主题 838|帖子 838|积分 2514

 

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()等
如以下例子会报错:
  1. select id, no, uid from user_order group by uid;
复制代码
 
改成下面的SQL则不报错:
  1. select uid from user_order group by uid;
复制代码
 
解决这个问题可以有三个方法:

方法一:
使用 group_concat() 或 any_value()
group_concat():将分到同一组的数据默认用逗号隔开作为返回数据
any_value():将分到同一组的数据里第一条数据的指定列值作为返回数据
修改后语句如下:
  1. select GROUP_CONCAT(id), GROUP_CONCAT(no), uid from user_order group by uid;
  2. select any_value(id), any_value(no), uid from user_order group by uid;
复制代码
 

方法二:
如果语句太多,变动太大,可以改数据库配置
首先查看当前sql_mode
  1. select @@global.sql_mode;
复制代码
 
可以看到返回以下值:
  1. ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
复制代码
 
重新设置,去掉ONLY_FULL_GROUP_BY即可:
  1. SET GLOBAL sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
复制代码
 
当然,如果想去掉所有限制也是可以的:
  1. SET GLOBAL sql_mode='';
复制代码
 
这个方法的好处是不用重启MySQL生效(需要注意的是在当前会话实例中是不生效的),坏处是重启后会恢复原样。

方法三:
永久生效,修改配置文件my.ini
在[mysqld]模块下新增一行配置:
  1. sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'
复制代码
 
保存,重启后生效。
 

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
回复

使用道具 举报

0 个回复

正序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

温锦文欧普厨电及净水器总代理

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表