MySQL社区

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

搜索
查看: 5300|回复: 0

[列及列类型] 与浮点比较有关的问题

[复制链接]
发表于 2007-10-30 12:14:18 | 显示全部楼层 |阅读模式
注意,下述部分主要与DOUBLE和FLOAT列相关,原因在于浮点数的不准确本质。MySQL使用64位十进制数值的精度执行DECIMAL操作,当处理DECIMAL列时,应能解决大多数常见的不准确问题。
浮点数有时会导致混淆,这是因为它们无法以准确值保存在计算机体系结构中。你在屏幕上所看到的值通常不是数值的准确值。对于FLOAT和DOUBLE列类型,情况就是如此。DECIMAL列能保存具有准确精度的值,这是因为它们是由字符串表示的。

在下面的示例中,介绍了使用DOUBLE时的问题:
  1. mysql> CREATE TABLE t1 (i INT, d1 DOUBLE, d2 DOUBLE);
  2. mysql> INSERT INTO t1 VALUES (1, 101.40, 21.40), (1, -80.00, 0.00),
  3.     -> (2, 0.00, 0.00), (2, -13.20, 0.00), (2, 59.60, 46.40),
  4.     -> (2, 30.40, 30.40), (3, 37.00, 7.40), (3, -29.60, 0.00),
  5.     -> (4, 60.00, 15.40), (4, -10.60, 0.00), (4, -34.00, 0.00),
  6.     -> (5, 33.00, 0.00), (5, -25.80, 0.00), (5, 0.00, 7.20),
  7.     -> (6, 0.00, 0.00), (6, -51.40, 0.00);

  8. mysql> SELECT i, SUM(d1) AS a, SUM(d2) AS b
  9.     -> FROM t1 GROUP BY i HAVING a <> b;

  10. +------+-------+------+
  11. | i    | a     | b    |
  12. +------+-------+------+
  13. |    1 |  21.4 | 21.4 |
  14. |    2 |  76.8 | 76.8 |
  15. |    3 |   7.4 |  7.4 |
  16. |    4 |  15.4 | 15.4 |
  17. |    5 |   7.2 |  7.2 |
  18. |    6 | -51.4 |    0 |
  19. +------+-------+------+
复制代码
结果是正确的。尽管前5个记录看上去不应能进行比较测试(a和b的值看上去没有什么不同),但它们能进行比较,这是因为显示的数值间的差异在十分位左右,具体情况取决于计算机的体系结构。

如果列d1和d2定义为DECIMAL而不是DOUBLE,SELECT查询的结果仅包含1行,即上面显示的最后1行。


[ 本帖最后由 jeff 于 2007-10-30 12:19 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|申请友链|小黑屋|Archiver|手机版|MySQL社区 ( 京ICP备07012489号   
联系人:周生; 联系电话:13911732319

GMT+8, 2024-4-16 17:04 , Processed in 0.068951 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表