【SQL】Group by 和Order By 后字段不一致引起的错误ORDER BY clause is not in GROUP BY clause

一、问题

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

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

陶洲川

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值