主頁 > 知識庫 > MySQL中ROUND函數(shù)進行四舍五入操作陷阱分析

MySQL中ROUND函數(shù)進行四舍五入操作陷阱分析

熱門標簽:地圖標注賺錢真假 遵義地圖標注app 外呼系統(tǒng)從哪買 商家地圖標注哪個好 合肥營銷外呼系統(tǒng)收費 德惠市地圖標注 深圳 陜西400電話如何申請 承德電腦地圖標注

本文實例講述了MySQL中ROUND函數(shù)進行四舍五入操作陷阱。分享給大家供大家參考,具體如下:

在MySQL中, ROUND 函數(shù)用于對查詢結(jié)果進行四舍五入,不過最近使用ROUND函數(shù)四舍五入時意外發(fā)現(xiàn)并沒有預(yù)期的那樣,本文將這一問題記錄下來,以免大家跟我一樣犯同樣的錯誤。

問題描述

假如我們有如下一個數(shù)據(jù)表 test ,建表語句如下

CREATE TABLE test (
 id int(11) NOT NULL AUTO_INCREMENT,
 field1 bigint(10) DEFAULT NULL,
 field2 decimal(10,0) DEFAULT NULL,
 field3 int(10) DEFAULT NULL,
 field4 float(15,4) DEFAULT NULL,
 field5 float(15,4) DEFAULT NULL,
 field6 float(15,4) DEFAULT NULL,
 PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

我們創(chuàng)建了一個名為 test 的表,出了 id 字段之外還包含了多個字段,擁有這不同的數(shù)據(jù)類型。我們向這個表中插入一條數(shù)據(jù)

INSERT INTO test (field1, field2, field3, field4, field5, field6) VALUE (100, 100, 100, 1.005, 3.5, 2.5);

插入之后表中的數(shù)據(jù)是這樣的

mysql> select * from test;
+----+--------+--------+--------+--------+--------+--------+
| id | field1 | field2 | field3 | field4 | field5 | field6 |
+----+--------+--------+--------+--------+--------+--------+
| 1 |  100 |  100 |  100 | 1.0050 | 3.5000 | 2.5000 |
+----+--------+--------+--------+--------+--------+--------+
1 rowin set (0.00 sec)

如果現(xiàn)在我們執(zhí)行下面這個SQL,你覺得結(jié)果會是什么樣的呢?

SELECT
 round(field1 * field4),
 round(field2 * field4),
 round(field3 * field4),
 round(field1 * 1.005),
 round(field2 * 1.005),
 round(field3 * 1.005),
 round(field5),
 round(field6)
FROM test;

最初一直以為這樣的結(jié)果肯定是都是 101 ,因為上面這六個取值結(jié)果都是對 100 * 1.005 進行四舍五入,結(jié)果肯定都是 101 才對,而后面兩個肯定是 4 和 3 才對,但是最終的結(jié)果卻是與設(shè)想的大相徑庭

*************************** 1. row ***************************
round(field1 * field4): 100
round(field2 * field4): 100
round(field3 * field4): 100
 round(field1 * 1.005): 101
 round(field2 * 1.005): 101
 round(field3 * 1.005): 101
    round(field5): 4
    round(field6): 2
1 rowin set (0.00 sec)

為什么會這樣?

同樣是100*1.005,為什么從數(shù)據(jù)庫中的字段相乘得到的結(jié)果和直接字段與小數(shù)相乘得到的不一樣呢?

對這個問題百思不得其解,各種百度谷歌無果。。。沒辦法,還得靠自己,這個時候最有用的就是官網(wǎng)文檔了,于是查詢了mysql官方文檔中關(guān)于ROUND函數(shù)的部分,其中包含下面兩條規(guī)則

  • For exact-value numbers, ROUND() uses the “round half up” rule對于精確的數(shù)值, ROUND 函數(shù)使用四舍五入
  • For approximate-value numbers, the result depends on the C library. On many systems, this means that ROUND() uses the “round to nearest even” rule: A value with any fractional part is rounded to the nearest even integer. (對于近似值,則依賴于底層的C函數(shù)庫,在很多系統(tǒng)中 ROUND 函數(shù)會使用“取最近的偶數(shù)”的規(guī)則)

通過這兩條規(guī)則,我們可以看出,由于我們在使用兩個字段相乘的時候,最終的結(jié)果是按照 float 類型處理的,而在計算機中 float 類型不是精確的數(shù),因此處理結(jié)果會按照第二條來,而直接整數(shù)字段與1.005這樣的小數(shù)運算的結(jié)果是因為兩個參與運算的值都是精確數(shù),因此按照第一條規(guī)則計算。從 field5 和 field6 執(zhí)行 ROUND 函數(shù)的結(jié)果可以明確的看確實是轉(zhuǎn)換為了最近的偶數(shù)。

總結(jié)

從這個例子中可以看到,在MySQL中使用ROUND還是要非常需要注意的,特別是當(dāng)參與計算的字段中包含浮點數(shù)的時候,這個時候計算結(jié)果是不準確的。

更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲過程技巧大全》、《MySQL數(shù)據(jù)庫鎖相關(guān)技巧匯總》及《MySQL常用函數(shù)大匯總》

希望本文所述對大家MySQL數(shù)據(jù)庫計有所幫助。

您可能感興趣的文章:
  • MySQL Where 條件語句介紹和運算符小結(jié)
  • MySQL中的運算符使用實例展示
  • MySQL筆記之運算符使用詳解
  • mySQL UNION運算符的默認規(guī)則研究
  • PHP MySQL應(yīng)用中使用XOR運算加密算法分享
  • 與MSSQL對比學(xué)習(xí)MYSQL的心得(五)--運算符
  • Mysql常用運算符與函數(shù)匯總
  • mysql 字符串長度計算實現(xiàn)代碼(gb2312+utf8)
  • MySQL幾點重要的性能指標計算和優(yōu)化方法總結(jié)

標簽:贛州 揚州 三門峽 貴州 南陽 新余 商丘 巴中

巨人網(wǎng)絡(luò)通訊聲明:本文標題《MySQL中ROUND函數(shù)進行四舍五入操作陷阱分析》,本文關(guān)鍵詞  MySQL,中,ROUND,函數(shù),進行,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL中ROUND函數(shù)進行四舍五入操作陷阱分析》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL中ROUND函數(shù)進行四舍五入操作陷阱分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章