高版本Mysql使用group by分组报错的解决方案

yizhihongxing

下面是详细的“高版本MySQL使用GROUP BY分组报错的解决方案”攻略。

问题描述

在高版本的MySQL(如MySQL5.7、MySQL8.0)中,对数据进行分组时,可能会出现以下报错信息:

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子句中或者使用聚合函数进行处理。否则就会报上述错误。

解决方案

1. 修改sql_mode参数值

我们可以通过修改MySQL的配置来改变sql_mode参数的值。

首先可以通过如下命令查看当前MySQL所使用的sql_mode参数:

SELECT @@GLOBAL.sql_mode;
SELECT @@SESSION.sql_mode;

如果看到返回值包含了only_full_group_by,那么就启用了该模式。

接下来,我们可以通过修改MySQL的my.cnf或者my.ini配置文件来去掉only_full_group_by模式。

在该文件中找到[mysqld]节点下的sql_mode参数(可能会有多个),然后把其中包含only_full_group_by的配置项去掉。

例如:

# 原始配置
sql_mode=ONLY_FULL_GROUP_BY,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

# 去掉only_full_group_by后的配置
sql_mode=NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

修改完配置后,重启MySQL服务,使新配置生效。

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

若不能修改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参数:

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

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

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

  4. 保存文件并重启MySQL服务。

  5. 使用如下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在使用GROUP BY分组时可能会遇到的报错,以及两种解决方案:

  1. 修改MySQL的sql_mode参数。

  2. 在SELECT语句中使用聚合函数。

这两种方案都能有效解决only_full_group_by模式带来的限制,让MySQL在分组查询时更加灵活方便。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:高版本Mysql使用group by分组报错的解决方案 - Python技术站

(0)
上一篇 2023年5月18日
下一篇 2023年5月18日

相关文章

  • 深入理解ES7的async/await的用法

    深入理解ES7的async/await的用法 ES7的async/await是一种基于Promise的异步编程语法糖,它使异步代码的编写变得更加直观和易于理解。在使用async/await之前,我们需要了解以下内容: 1. async函数 async函数是异步函数的简写,返回的是一个Promise对象。可以通过在函数声明时添加async关键字来定义一个asy…

    database 2023年5月22日
    00
  • sqlserver中关于WINDOWS性能计数器的介绍

    SQL Server中关于WINDOWS性能计数器的介绍 什么是WINDOWS性能计数器 Windows性能计数器是由微软开发和发布的一组工具,用于监控和优化服务器和应用程序性能。它们可以收集和显示有关操作系统、应用程序甚至硬件的性能指标,例如CPU使用率、内存使用率、磁盘I/O等等。 SQL Server中的WINDOWS性能计数器 数据库管理员可以使用W…

    database 2023年5月21日
    00
  • Mysql 执行一条语句的整个过程详细

    Mysql 执行一条语句的整个过程可以分为以下几个步骤: 客户端发送 SQL 语句到服务器,其中包括数据库名、表名、操作类型等信息。 服务器接收到 SQL 语句后,解析 SQL 语句,生成执行计划。 服务器根据执行计划执行 SQL 语句,包括查询、插入、更新、删除等操作。 执行完成后,服务器将结果返回给客户端。 下面分别以查询和插入两个例子来详细讲解整个过程…

    database 2023年5月21日
    00
  • Php中使用Select 查询语句的实例

    下面是关于在PHP中使用Select查询语句的攻略: 1. 准备工作 在使用Select查询语句前,需要进行以下准备工作: 1.1 连接数据库 在PHP中连接数据库需要使用mysqli扩展或PDO扩展,这里以mysqli扩展为例,代码如下: // 创建连接 $conn = new mysqli($servername, $username, $passwor…

    database 2023年5月21日
    00
  • MSSQL中删除用户时数据库主体在该数据库存中拥有架构 无法删除的解决方法

    当你在MSSQL中删除用户时,如果该用户拥有在该数据库中创建的架构或者有其他对象的所有权,则会遇到错误消息说无法删除该用户,因为该用户是数据库的主体。下面是解决该问题的完整攻略。 1. 确认用户是否拥有架构或其他对象所有权 首先,我们需要确认用户是否拥有在该数据库中创建的架构或其他对象的所有权。我们可以使用以下查询来查找用户所有权: SELECT * FRO…

    database 2023年5月21日
    00
  • mysql5的sql文件导入到mysql4的方法

    在将 MySQL 5 的 SQL 文件导入到 MySQL 4 上时,需要注意最新版本的 MySQL 5中一些功能并不存在于 MySQL 4 中,如需导入,需要进行一些设置。以下是具体的攻略过程: 1. 导出 SQL 文件时的设置 当我们在 MySQL 5 上导出 SQL 文件时,需要使用如下的参数进行设置: mysqldump -u username -p …

    database 2023年5月22日
    00
  • PHP/Javascript/CSS/jQuery常用知识大全详细整理第2/2页

    关于“PHP/Javascript/CSS/jQuery常用知识大全详细整理第2/2页”的完整攻略,我来为你进行详细讲解。 攻略概览 PHP部分 表单处理 文件操作 MySQL数据库操作 Javascript部分 基础语法 DOM操作 AJAX CSS部分 盒模型 居中布局 响应式设计 jQuery部分 基础语法 DOM操作 事件绑定 PHP部分 表单处理 …

    database 2023年5月22日
    00
  • 详解Java8中的lambda表达式、::符号和Optional类

    下面是“详解Java8中的lambda表达式、::符号和Optional类”的攻略。 什么是Lambda表达式? Lambda表达式是Java8中引入的一种新的语法,它允许开发者以更简洁、清晰的方式编写代码。Lambda表达式通常用于函数式编程,与传统的面向对象编程风格不同。 Lambda表达式由三部分组成:参数列表、箭头符号(->)和函数体。 例如,…

    database 2023年5月21日
    00
合作推广
合作推广
分享本页
返回顶部