🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
~~~ 1055 - Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'csc_risk.a.DefaultDate' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by, Time: 0.035000s  ~~~ SELECT VERSION() 查询数据版本发现确实是5.7版本 原因分析:MySQL5.7版本默认设置了 mysql sql\_mode = only\_full\_group\_by 属性,导致报错。 知道原因就好办: 下载安装的是最新版的mysql5.7.x版本,默认是开启了 only_full_group_by 模式的,但开启这个模式后,原先的 group by 语句就报错,然后又把它移除了。 一旦开启 only_full_group_by ,感觉,group by 将变成和 distinct 一样,只能获取受到其影响的字段信息,无法和其他未受其影响的字段共存,这样,group by 的功能将变得十分狭窄了 only_full_group_by 模式开启比较好。因为在 mysql 中有一个函数: any_value(field) 允许,非分组字段的出现(和关闭 only_full_group_by 模式有相同效果)。 ## 解决方案一 ### 1、查看sql\_mode SELECT @@sql\_mode; 查询出来的值为: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 ### 2、去掉ONLY\_FULL\_GROUP\_BY,重新设置值。 在mysql.ini 里面,如果找不到sql\_mode 则直接放进去[mysqld]里面 sql_mode =STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION ### 3 重启即可 /etc/init.d/mysql restart lnmp一键包的mysql配置有个坑,以为只有一个配置一直改/etc/my.cnf这个文件,一直重启不生效,为了度娘才知道,文件my.cnf有两个,一个在/etc/my.cnf,一个是/usr/local/mysql/my.cnf ## 解决方案二:使用函数ANY\_VALUE()包含报错字段(不想重启数据库,不想改数据库配置的可以用该方法) 将上述报错语句改成: ~~~ SELECT ANY_VALUE(ID),USER_ID,ANY_VALUE(problems),ANY_VALUE(last_updated_date) FROM t_iov_help_feedback GROUP BY USER_ID; ~~~ ![](https://img-blog.csdnimg.cn/20210223160822931.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTI2NjA0NjQ=,size_16,color_FFFFFF,t_70) 可以看到,结果能正常查询了,根据需要自己改查询字段的别名就行。 ANY\_VALUE()函数说明: ~~~ MySQL有any_value(field)函数,它主要的作用就是抑制ONLY_FULL_GROUP_BY值被拒绝。 这样sql语句不管是在ONLY_FULL_GROUP_BY模式关闭状态还是在开启模式都可以正常执行,不被mysql拒绝。 any_value()会选择被分到同一组的数据里第一条数据的指定列值作为返回数据。 官方有介绍,地址:https://dev.mysql.com/doc/refman/5.7/en/miscellaneous-functions.html#function_any-value ~~~ 例子: ~~~ Db::name('room')->field('any_value(course_id) as course_id,any_value(room_id) as room_id,count(room_id) as num_total')->where('course_id','>',0)->group('course_id')->select(); ~~~