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()等
如以下例子会报错:
**select id, no, uid from user_order group by uid;**
改成下面的SQL则不报错:
**select uid from user_order group by uid;**
解决这个问题
使用 group_concat() 或 any_value()
group_concat():将分到同一组的数据默认用逗号隔开作为返回数据
any_value():将分到同一组的数据里第一条数据的指定列值作为返回数据
修改后语句如下:
select GROUP_CONCAT(id), GROUP_CONCAT(no), uid from user_order group by uid;
select any_value(id), any_value(no), uid from user_order group by uid;
其他方法:
还有很多人说修改配置文件,本人没有试过!