目录
问题
原因
解决方案
问题
看这条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 会尽可能地对浮点数进行分组。但是,由于浮点数在计算机中的表示方式可能会导致精度问题,因此可能会出现意外的结果。
解决方案
把字段类型改成整形或者字符串
查询结果就正常了: