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报错:The last packet sent successfu
这篇文章主要介绍了解决MySQL报错:The last packet sent successfully to the server was 0 milliseconds ago问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2023-12-12MariaDB(MySQL)创建、删除、选择及数据类型使用详解
这篇文章主要介绍了MariaDB(MySQL)创建、删除、选择及数据类型使用详解的相关资料,需要的朋友可以参考下2016-09-09mysql中insert并发问题(on DUPLICATE KEY UPDATE)
本文主要介绍了mysql中insert并发问题(on DUPLICATE KEY UPDATE),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2023-01-01Windows11下MySQL 8.0.29 安装配置方法图文教程
这篇文章主要为大家详细介绍了Windows11下MySQL 8.0.29 安装配置方法图文教程,文中安装步骤介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2022-07-07
最新评论