mysql高版本(8.0+)group_by报错的处理方法

 更新时间:2023年09月03日 16:21:29   作者:*郑*  
本文主要介绍了mysql高版本(8.0+)group_by报错的处理方法,这个错误一般发生在mysql 5.7以及 5.7以上的版本中,本文就来介绍一下两种解决方法,感兴趣的可以了解一下

1. 原因

这个错误一般发生在mysql 5.7以及 5.7以上的版本中,其原因是mysql的默认配置中,sql_mode=“ONLY_FULL_GROUP_BY” 这个配置严格执行了 ‘SQL92标准’,查询字段没有在group by 字段后同时出现,那么sql语句就不合法,就会抛出错误

Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'xxx' 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模式,对于GROUP BY操作,要求SELECT语句中的字段必须出现在GROUP BY子句中或者使用聚合函数进行处理。否则就会报上述错误。

2. 处理方法

连接mysql库,执行一下语句,查看sql_mode

select @@GLOBAL.sql_mode;

2.1 临时方法,重启后失效

SET GLOBAL sql_mode='STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION';

2.2 修改配置my.ini文件

在[mysqld]下面添加以下代码

sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION

3. 对查询结果中的字段应用聚合函数

若不能修改MySQL的配置文件,或者需要在特定场景使用原始的sql_mode值,我们也可以尝试在查询语句中对未出现在GROUP BY子句中的字段应用聚合函数来解决报错问题。

例如:

SELECT user_id, SUM(score) FROM scores GROUP BY user_id;

该语句会报错,因为SELECT语句中的score字段未出现在GROUP BY子句中。但是,我们可以尝试使用聚合函数:

SELECT user_id, MAX(score) FROM scores GROUP BY user_id;

该语句中的score字段被应用了MAX聚合函数,这样就符合了only_full_group_by模式的要求,不会报错。

示例

下面提供两个具体的示例来展示如何使用上述解决方案。假设我们有如下的scores数据表:

id   user_id   score
1    100      88
2    100      93
3    101      73
4    102      85
5    102      91

示例1:修改sql_mode参数值

我们可以通过如下步骤来修改MySQL的sql_mode参数:

打开MySQL的配置文件my.cnf或my.ini。

找到[mysqld]节点下的sql_mode参数(可能会有多个)。

将其值修改为:sql_mode=NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION。

保存文件并重启MySQL服务。

使用如下SQL查询语句,测试是否能正确查询出score字段的平均值:

SELECT AVG(score) FROM scores GROUP BY user_id;

示例2:使用聚合函数

在不修改MySQL的sql_mode参数的情况下,我们可以改变查询语句,使用聚合函数来解决only_full_group_by模式带来的限制。

例如,下列SQL语句查询出每个用户的最小成绩:

SELECT user_id, MIN(score) FROM scores GROUP BY user_id;

在这个查询语句中,score字段被应用了MIN聚合函数,符合only_full_group_by模式的要求。因此可以正常执行,并正确返回结果。

到此这篇关于mysql高版本(8.0+)group_by报错的处理方法的文章就介绍到这了,更多相关mysql group_by报错内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • springboot日志的使用与多个日志框架冲突问题及解决

    springboot日志的使用与多个日志框架冲突问题及解决

    文章介绍了日志级别、日志分类、logback、log4j、log4j2的使用方法,并讨论了统一日志标准的重要性,还提到了各种日志类Jar包的用途,以及如何实现SLF4J门面以兼容不同的日志框架
    2025-02-02
  • SpringBoot全局异常处理方式

    SpringBoot全局异常处理方式

    本文详细介绍了Spring Boot中异常处理的多种方案,包括基于请求转发、异常处理器、过滤器等方式,并对其特点、实现方式和适用场景进行了详细介绍,作者推荐了基于请求转发和异常处理器+请求转发补充的方案,认为它们能实现统一的全局异常处理,并能自定义统一响应信息格式
    2024-12-12
  • java开发中防止重复提交的几种解决方案

    java开发中防止重复提交的几种解决方案

    我们日常开发中有很多的应用场景都会遇到重复提交问题,下面这篇文章主要给大家介绍了关于java开发中防止重复提交的几种解决方案,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-10-10
  • 在IDEA中配置tomcat并创建tomcat项目的图文教程

    在IDEA中配置tomcat并创建tomcat项目的图文教程

    这篇文章主要介绍了在IDEA中配置tomcat并创建tomcat项目的图文教程,需要的朋友可以参考下
    2020-07-07
  • 基于Spring Boot保护Web应用程序

    基于Spring Boot保护Web应用程序

    这篇文章主要介绍了基于Spring Boot保护Web应用程序,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-03-03
  • 带你轻松了解Modbus协议

    带你轻松了解Modbus协议

    这篇文章主要给大家介绍了关于Modbus协议的相关资料,此协议定义了一个控制器能认识使用的消息结构,而不管它们是经过何种网络进行通信的,需要的朋友可以参考下
    2021-11-11
  • java中double强制转换int引发的OOM问题记录

    java中double强制转换int引发的OOM问题记录

    这篇文章主要介绍了java中double强制转换int引发的OOM问题记录,本文给大家分享问题排查过程,感兴趣的朋友跟随小编一起看看吧
    2024-10-10
  • Java如何定位进程中占用CPU或内存最多的线程

    Java如何定位进程中占用CPU或内存最多的线程

    在排查 Java 性能问题时,定位占用 CPU 或内存最多的线程是关键步骤,本文为大家介绍了针对两种场景的具体排查方法,希望对大家有一定的帮助
    2025-05-05
  • java文字转语音播报功能的实现方法

    java文字转语音播报功能的实现方法

    这篇文章主要给大家介绍了关于java文字转语音播报功能的实现方法,文中通过示例代码介绍的非常详细,对大家学习或者使用java具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-07-07
  • Java中的远程方法调用之RPC使用

    Java中的远程方法调用之RPC使用

    本文介绍了RPC的基本概念、核心思想及其在分布式系统中的作用,重点讲解了Java中的三种RPC实现方式:RMI、Hessian和Dubbo,分别从适用场景、核心特点等方面做了对比对比较,并并提供了其基本实现代码示例,总结了各框架的优缺点,为实际开发中选择合适的技术栈提供了参考
    2026-05-05

最新评论