一、问题
1.1、环境
电脑环境:Windows 10;
开发工具:IntelliJ IDEA;
数据库环境:Redis 3.2.100
JDK环境: Jdk1.8;
1.2、问题
java.sql.SQLSyntaxErrorException: Expression #1 of ORDER BY clause is not in GROUP BY clause and contains
nonaggregated column 'a.create_time' which is not functionally dependent on columns in GROUP BY clause;
this is incompatible with sql_mode=only_full_group_by
二、解答
这里,有的同学会以为是sql_mode的问题,然后去改sql_mode的配置文件;
其实不是,我们仔细看报错的日志,首先总览全文,是SQL格式错误异常;其次说了第一个参数(根据Expression #1得知),Order by 的从句不在Group by从句之中,并且包含非聚合的字段create_time,这个字段不是group by 从句的功能性依赖;
<!--省略了前面的SQL-->
GROUP BY
(
date_format(a.create_time, '%Y-%m-%d')
)
ORDER BY a.create_time asc
所以,通过观察得知,Mysql编译器认为,我们的order by 从句后面的字段,不是group by 从句中的字段,将他们判定为2个字段,所以报错;我们只要将两个字段的格式改成一样的即可:
GROUP BY
(
date_format(a.create_time, '%Y-%m-%d')
)
ORDER BY date_format(a.create_time, '%Y-%m-%d') asc
完毕~
三、总结
欢迎关注我的
CSDN博客: https://blog.csdn.net/River_Continent
微信公众号:幕桥社区
知乎:张牧野, https://www.zhihu.com/people/zhang-mu-ye-37-76/activities
简书: https://www.jianshu.com/u/02c0096cbfd3