我们都知道 浮点型 不是很精确的,所以在进行类型转化的时候就会出现很多意向不到的问题
我使用php给大家用代码说说这事
$a = 2.01; var_dump(sprintf('%.20F', $a * 100));//string(24) "200.99999999999997157829" var_dump( intval( $a * 100) );//int(200)
上面的结果很出人意料吧,2.01 * 100 应该是201吧,居然是200.99999999.... 这样就可以解释 为什么 后面的转化成整形变成200了
如何解决这种问题了? float => int 之前先使用round
$a = 2.01; var_dump(sprintf('%.20F', $a * 100));//string(24) "200.99999999999997157829" var_dump( intval( round($a * 100) ) );//int(201)
其实大部分情况都不用太考虑这种问题,但是在支付系统中就要考虑这个问题,因为商品的价格一般需要支付到分,上面的2.01 就是到分。这个时候如果订单数据表中存放的价格单位是分就有问题了, 根据上面的事例很有可能存的就是200,210的商品,最后已200结算了。
终极解决方案 对于精度有要求的使用mysql 的 decimal类型