首页 相关文章 MySQL中与浮点比较有关问题的解决

MySQL中与浮点比较有关问题的解决

注意,下述部分主要与DOUBLE和FLOAT列相关,原因在于浮点数的不准确本质。MySQL使用64位十进制数值的精度执行DECIMAL操作,当处理DECIMAL列时,应能解决大多数常见的不准确问题。

浮点数有时会导致混淆,这是因为它们无法以准确值保存在计算机体系结构中。你在屏幕上所看到的值通常不是数值的准确值。对于FLOAT和DOUBLE列类型,情况就是如此。DECIMAL列能保存具有准确精度的值,这是因为它们是由字符串表示的。

在下面的示例中,介绍了使用DOUBLE时的问题:

mysql CREATE TABLE t1 (i INT, d1 DOUBLE, d2 DOUBLE);
mysql INSERT INTO t1 VALUES (1, 101.40, 21.40), (1, -80.00, 0.00),
- (2, 0.00, 0.00), (2, -13.20, 0.00), (2, 59.60, 46.40),
- (2, 30.40, 30.40), (3, 37.00, 7.40), (3, -29.60, 0.00),
- (4, 60.00, 15.40), (4, -10.60, 0.00...[ 查看全文 ]

2016-02-19 标签:

MySQL中与浮点比较有关问题的解决的相关文章

手机页面
收藏网站 回到头部