IT貓撲網(wǎng):您身邊最放心的安全下載站! 最新更新|軟件分類|軟件專題|手機版|論壇轉(zhuǎn)貼|軟件發(fā)布

您當(dāng)前所在位置:首頁數(shù)據(jù)庫MYSQL → 快速解決 MySQL中與浮點比較有關(guān)的問題

快速解決 MySQL中與浮點比較有關(guān)的問題

時間:2015/6/28來源:IT貓撲網(wǎng)作者:網(wǎng)管聯(lián)盟我要評論(0)

注意,下述部分主要與DOUBLE和FLOAT列相關(guān),原因在于浮點數(shù)的不準(zhǔn)確本質(zhì)。mysql使用64位十進(jìn)制數(shù)值的精度執(zhí)行DECIMAL操作,當(dāng)處理DECIMAL列時,應(yīng)能解決大多數(shù)常見的不準(zhǔn)確問題。

浮點數(shù)有時會導(dǎo)致混淆,這是因為它們無法以準(zhǔn)確值保存在計算機體系結(jié)構(gòu)中。你在屏幕上所看到的值通常不是數(shù)值的準(zhǔn)確值。對于FLOAT和DOUBLE列類型,情況就是如此。DECIMAL列能保存具有準(zhǔn)確精度的值,這是因為它們是由字符串表示的。

在下面的示例中,介紹了使用DOUBLE時的問題:

以下為引用的內(nèi)容:
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 |
+------+-------+------+

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

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

關(guān)鍵詞標(biāo)簽:有關(guān),問題,比較,解決,

相關(guān)閱讀

文章評論
發(fā)表評論

熱門文章 10款MySQL數(shù)據(jù)庫客戶端圖形界面管理工具推薦10款MySQL數(shù)據(jù)庫客戶端圖形界面管理工具推薦MySQL常用維護(hù)管理工具MySQL常用維護(hù)管理工具Linux VPS/服務(wù)器上輕松導(dǎo)入、導(dǎo)出MySQL數(shù)據(jù)Linux VPS/服務(wù)器上輕松導(dǎo)入、導(dǎo)出MySQL數(shù)據(jù)MySQL復(fù)制的概述、安裝、故障、技巧、工具MySQL復(fù)制的概述、安裝、故障、技巧、工具

相關(guān)下載

人氣排行 MySQL數(shù)據(jù)庫啟動失敗1067進(jìn)程意外終止的解決辦法總結(jié)Mysql 1045錯誤解決辦法10款MySQL數(shù)據(jù)庫客戶端圖形界面管理工具推薦MySQL服務(wù)器進(jìn)程CPU占用100%解決辦法MySQL導(dǎo)出導(dǎo)入命令的用例MySQL無法啟動、無法停止各種解決方法總結(jié)三種常用的MySQL建表語句Mysql清空表的實現(xiàn)方法