日本搞逼视频_黄色一级片免费在线观看_色99久久_性明星video另类hd_欧美77_综合在线视频

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > 數據庫 > MySql > 快速解決 MySQL中與浮點比較有關的問題

快速解決 MySQL中與浮點比較有關的問題

來源:程序員人生   發布時間:2014-04-06 11:52:17 閱讀次數:3695次

注意,下述部分主要與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), (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 |
+------+-------+------+

結果是正確的。盡管前5個記錄看上去不應能進行比較測試(a和b的值看上去沒有什么不同),但它們能進行比較,這是因為顯示的數值間的差異在十分位左右,具體情況取決于計算機的體系結構。

如果列d1和d2定義為DECIMAL而不是DOUBLE,SELECT查詢的結果僅包含1行,即上面顯示的最后1行。

生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 99热99精品| 成人免费视频观看视频 | 欧美日韩精品在线观看 | 亚洲一区二区在线免费观看 | 福利一区二区 | 欧美性video 精品成人久久 | 亚洲欧美综合精品久久成人 | 国产日韩精品在线 | 日韩精品一区二区三区在线播放 | 一区二区三区精品 | 国产成人在线观看免费网站 | 日本精品一区二区三区四区的功能 | 日韩一级片在线播放 | 在线二区 | 精品成人在线观看 | 日韩不卡在线视频 | 黄色福利网站 | 成人做爰www免费看视频网战 | 日韩欧美视频在线 | 九九久久精品一区二区三区 | 久久久久久人 | 免费福利视频一区二区三区 | 久久精品网站免费观看 | a集毛片 | 黄色成人小视频 | 日韩精品在线观看一区 | 在线一区二区三区 | 欧美成人精品一区二区 | 日韩欧美大片在线观看 | 日日网| 国产乱码精品1区2区3区 | 成人一区二区视频 | 欧美精品久久久久久久免费软件 | 黄色小视频在线观看 | 国产一区二区三区欧美 | 高清一区二区三区 | 欧美专区日韩专区 | 午夜精品久久久久久久久久蜜桃 | 国产一区一一区高清不卡 | 国产免费一级片 | 久久y|