MySQL 浮點型的精度范圍與四舍五入
問題描述
問題解答
回答1:因為,你在創(chuàng)建表的時候,指定的 f3 是 float(6,2) ,那這個 6 和 2 是什么意思?6 是數(shù)字總位數(shù)。2是小數(shù)點后只保留2位。所以會顯示成 9999.99 即總共 6 個9,小數(shù)后是 2 位
回答2:建議使用decimal,尤其是涉及到錢的問題的時候,在mysql中float、double(或real)是浮點數(shù),decimal(或numberic)是定點數(shù)。
浮點數(shù)相對于定點數(shù)的優(yōu)點是在長度一定的情況下,浮點數(shù)能夠表示更大的數(shù)據(jù)范圍;它的缺點是會引起精度問題。
在今后關(guān)于浮點數(shù)和定點數(shù)的應(yīng)用中,大家要記住以下幾點:
1、浮點數(shù)存在誤差問題;
2、對貨幣等對精度敏感的數(shù)據(jù),應(yīng)該用定點數(shù)表示或存儲;
3、編程中,如果用到浮點數(shù),要特別注意誤差問題,并盡量避免做浮點數(shù)比較;
4、要注意浮點數(shù)中一些特殊值的處理。可以看看這個http://blog.csdn.net/lingmao5...
回答3:float(m,d) 中,m 代表總位數(shù), d 代表小數(shù)點右邊的位數(shù)
create table example3 ( f1 float, f2 float(5,2), d1 double, d2 double(5,2));insert into example3(f1, f2, d1, d2) values(3.141592657,3.141592657,3.141592657,3.141592657), (3,3,3,3);
顯示如下:
f1f2d1d23.141593.143.1415926573.1433.0033.00解釋:
不指定 m,d :按照 float 與 double 的范圍來取值
指定 m,d : 按照 m,d 的值來取,超過則四舍五入,不超過則補 0
相關(guān)文章:
1. PHP類中的$this2. css - 新手做響應(yīng)式布局, 斷點過后右側(cè)出現(xiàn)空白,求幫助,謝謝。3. javascript - webpack dllPlugin 是不是只用于開發(fā)環(huán)境?4. javascript - nodejs 如何同步執(zhí)行某些模塊函數(shù)?5. javascript - QQ第三方登錄的問題6. python - 如何1次執(zhí)行多條SQL語句7. mysql - 兩表關(guān)聯(lián)查詢,按條件篩選結(jié)果8. javascript - 正則的截取匹配問題求助9. Python中使用超長的List導(dǎo)致內(nèi)存占用過大10. 前端 - css3中,這樣的代碼為什么會顯示成圖片?
