=a14c id=zoom>注释:以下部分主要和DOUBLE和FLOAT列相关
![](/icons/26453dou.gif)
原因在于浮点数
![](/icons/26453de.gif)
不准确本质
MySQL使用64位十进制数值
![](/icons/26453de.gif)
精度执行DECIMAL操作
![](/icons/26453dou.gif)
当处理DECIMAL列时
![](/icons/26453dou.gif)
应能解决大多数常见
![](/icons/26453de.gif)
不准确问题
![](/icons/26453dou2.gif)
浮点数有时会导致混淆
![](/icons/26453dou.gif)
这是
![](/icons/26453yinwei.gif)
它们无法以准确值保存在计算机体系结构中
![](/icons/26453dou2.gif)
你在屏幕上所看到
![](/icons/26453de.gif)
值通常不是数值
![](/icons/26453de.gif)
准确值
![](/icons/26453dou2.gif)
对于FLOAT和DOUBLE列类型
![](/icons/26453dou.gif)
情况就是如此
![](/icons/26453dou2.gif)
DECIMAL列能保存具有准确精度
![](/icons/26453de.gif)
值
![](/icons/26453dou.gif)
这是
![](/icons/26453yinwei.gif)
它们是由
![](/icons/26453zifu.gif)
串表示
![](/icons/26453de.gif)
![](/icons/26453dou2.gif)
在下面
![](/icons/26453de.gif)
举例中
![](/icons/26453dou.gif)
介绍了使用DOUBLE时
![](/icons/26453de.gif)
问题:
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), (4, -34.00, 0.00),
-> (5, 33.00, 0.00), (5, -25.80, 0.00), (5, 0.00, 7.20),
-> (6, 0.00, 0.00), (6, -51.40, 0.00);
mysql> SELECT i, SUM(d1) AS a, SUM(d2) AS b
-> FROM t1 GROUP BY i HAVING a <> b;
+------+-------+------+
| i | a | b |
+------+-------+------+
| 1 | 21.4 | 21.4 |
| 2 | 76.8 | 76.8 |
| 3 | 7.4 | 7.4 |
| 4 | 15.4 | 15.4 |
| 5 | 7.2 | 7.2 |
| 6 | -51.4 | 0 |
+------+-------+------+
结果是正确
![](/icons/26453de.gif)
![](/icons/26453dou2.gif)
尽管前5个记录看上去不应能进行比较测试(a和b
![](/icons/26453de.gif)
值看上去没有什么区别)
![](/icons/26453dou.gif)
但它们能进行比较
![](/icons/26453dou.gif)
这是
![](/icons/26453yinwei.gif)
显示
![](/icons/26453de.gif)
数值间
![](/icons/26453de.gif)
差异在十分位左右
![](/icons/26453dou.gif)
具体情况取决于计算机
![](/icons/26453de.gif)
体系结构
![](/icons/26453dou2.gif)
如果列d1和d2定义为DECIMAL而不是DOUBLE
![](/icons/26453dou.gif)
SELECT查询
![](/icons/26453de.gif)
结果仅包含1行
![](/icons/26453dou.gif)
即上面显示
![](/icons/26453de.gif)
最后1行
延伸阅读
最新评论