mysql语句使用group by报错问题解决方案

mysql8版本出现下面问题

 Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'msgList.lastContent' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

这个问题产生的原因是新版本的mysql不支持sql_mode=only_full_group_by

解决方案是设置别的

set @@global.sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';

一劳永逸的方法,重启mysql服务也不会失效,在mysql配置文件my.in里配置如下,再重启mysql服务

[mysqld]
sql_model=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
MySQL 8中,当使用GROUP BY语句时,如果SELECT列表中的列没有在GROUP BY子句中出现或者没有使用聚合函数进行计算,就会。这是由于MySQL 8中默认启用了严格模式(sql_mode=only_full_group_by),要求SELECT列表中的列必须要么在GROUP BY子句中出现,要么使用聚合函数进行计算。所以如果你的代码中出现了类似于"Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column"的,那是因为你的SELECT列表中的某个列未在GROUP BY子句中出现,也没有使用聚合函数进行计算,与严格模式不兼容。 举个例子来解释,假设有一个名为student的表,其中包含sno(学号)和sname(学生姓名)两个列,如果你执行以下SQL语句: SELECT sno, sname FROM student GROUP BY sno; 在MySQL 8中,将会,因为sname列没有在GROUP BY子句中出现,也没有使用聚合函数进行计算。 为了解决这个问题,你可以将所有未在GROUP BY子句中出现的列都添加到GROUP BY子句中,或者使用聚合函数进行计算。比如,你可以执行以下SQL语句来避免: SELECT sno, MAX(sname) FROM student GROUP BY sno; 这样就能够正确地使用GROUP BY语句进行查询了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [MySQL8.x group_by的4种解决方法](https://blog.csdn.net/hefeng_aspnet/article/details/129078794)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [mysql8中的groupby](https://blog.csdn.net/appleyuchi/article/details/106305043)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

飞流银河

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

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

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

打赏作者

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

抵扣说明:

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

余额充值