MySQL进行group by字段返回大量异常结果的问题解决

 更新时间:2024年05月05日 10:11:01   作者:蒾酒  
本文主要介绍了MySQL进行group by字段返回大量异常结果的问题解决,文中通过代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

问题

看这条sql

CH2O这个字段的取值只有1,2,3,正常进行group by 分类累加统计返回结果应该是这样:

[
    {
        "CH2O": 2.0,
        "insufficient_weight": 142,
        "Normal_Weight": 164,
        "Overweight_Level_I": 154,
        "Overweight_Level_II": 186,
        "Obesity_Type_I": 173,
        "Obesity_Type_II": 177,
        "Obesity_Type_III": 114
    },
    {
        "CH2O": 3.0,
        "insufficient_weight": 46,
        "Normal_Weight": 40,
        "Overweight_Level_I": 76,
        "Overweight_Level_II": 57,
        "Obesity_Type_I": 110,
        "Obesity_Type_II": 38,
        "Obesity_Type_III": 149
    },
    {
        "CH2O": 1.0,
        "insufficient_weight": 84,
        "Normal_Weight": 83,
        "Overweight_Level_I": 60,
        "Overweight_Level_II": 47,
        "Obesity_Type_I": 68,
        "Obesity_Type_II": 82,
        "Obesity_Type_III": 61
    }
]

但是我实际运行查询到的结果是这样:

返回的数据非常多,这不合理,经过仔细排查发现了出现该问题的原因。

原因

这样一看该列存储数据值只有1,2,3为啥会group by出那么多数据呢

原来是该列的数据类型设置成了浮点型

在 MySQL 中,如果你使用浮点型字段进行 GROUP BY 操作,MySQL 会尽可能地对浮点数进行分组。但是,由于浮点数在计算机中的表示方式可能会导致精度问题,因此可能会出现意外的结果。

解决方案

把字段类型改成整形或者字符串

查询结果就正常了:

到此这篇关于MySQL进行group by字段返回大量异常结果的问题解决的文章就介绍到这了,更多相关MySQL group by返回异常内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL数据库索引order by排序精讲

    MySQL数据库索引order by排序精讲

    我们今天说的并不是大数据下该如何优雅的排序,如何提升排序性能的问题,我们来仔细分析说一说MySQL中的排序问题,希望可以对正在阅读的同学们有所启迪帮助
    2021-11-11
  • Mysql中事务ACID的实现原理详解

    Mysql中事务ACID的实现原理详解

    这篇文章主要给大家介绍了关于Mysql中事务ACID实现原理的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Mysql具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-05-05
  • mysql实用技巧之比较两个表是否有不同数据的方法分析

    mysql实用技巧之比较两个表是否有不同数据的方法分析

    这篇文章主要介绍了mysql实用技巧之比较两个表是否有不同数据的方法,结合实例形式分析了mysql数据表比较的相关操作技巧与注意事项,需要的朋友可以参考下
    2019-12-12
  • 在MySQL中同时查找两张表中的数据的示例

    在MySQL中同时查找两张表中的数据的示例

    这篇文章主要介绍了在MySQL中同时查找两张表中的数据的示例,即一次查询操作返回两张表的结果,需要的朋友可以参考下
    2015-07-07
  • MySQL学习教程之聚簇索引

    MySQL学习教程之聚簇索引

    这篇文章主要给大家介绍了关于MySQL学习教程之聚簇索引的相关资料,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • MySQL优化教程之超大分页查询

    MySQL优化教程之超大分页查询

    这篇文章主要给大家介绍了关于MySQL优化教程之超大分页查询的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • 安装mysql-8.0.19-winx64遇到的问题:Can''t create directory ''xxxx\Database\''

    安装mysql-8.0.19-winx64遇到的问题:Can''t create directory ''xxxx\Da

    这篇文章主要介绍了安装mysql-8.0.19-winx64遇到的坑 ,Can't create directory 'xxxx\Database\',非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-02-02
  • MySQL 使用SQL语句修改表名的实现

    MySQL 使用SQL语句修改表名的实现

    这篇文章主要介绍了MySQL 使用SQL语句修改表名的实现操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-04-04
  • MySQL5.7的sql脚本导入到MySQL5.5出错3种解决方案

    MySQL5.7的sql脚本导入到MySQL5.5出错3种解决方案

    笔者需要将使用MySQL5.7数据库的网站挪入winows服务器,目标服务器使用的是MySQL5.5,因为兼顾到以前的网站,MySQL不能升级。遇到MySQL5.7的sql脚本导入到MySQL5.5出错,总结了3种解决方案,总有一个方案适合你。
    2023-06-06
  • MySQL索引的优化之LIKE模糊查询功能实现

    MySQL索引的优化之LIKE模糊查询功能实现

    这篇文章主要介绍了MySQL索引的优化之LIKE模糊查询功能实现,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧
    2025-04-04

最新评论