float存储4个字节,对应32位,32位中又包含了符号位、指数数、有效位等,当十进制数转化为二进制数超出位数会出现截断的情况,引发精度丢失。而在MySQL数据存储float数据时发生精度丢失会导致存储数据近似原数据,这就导致使用原数据等值查询而查询不到,但是范围查询可以查询的情况。另外在对float进行精度限制引发的四舍五入也存在精度丢失问题,需要注意的是此时的精度丢失是发生在四舍五入之后,即先进行四舍五入再进行存储(精度可能丢失)。
比如:11.9,可存但是等值查询11.9查询不到,是因为11.9存储的过程存在精度丢失,数据库存储的是近11.9的二进制,但是展示结果还是11.9。在设置字段float(M,2)时,存储0.246会先进行四舍五入得到0.25,数据库存储0.25二进制不存在精度丢失,可以进行等值查询。