MySQL 浮點型的精度范圍與四舍五入
問題描述
問題解答
回答1:因為,你在創建表的時候,指定的 f3 是 float(6,2) ,那這個 6 和 2 是什么意思?6 是數字總位數。2是小數點后只保留2位。所以會顯示成 9999.99 即總共 6 個9,小數后是 2 位
回答2:建議使用decimal,尤其是涉及到錢的問題的時候,在mysql中float、double(或real)是浮點數,decimal(或numberic)是定點數。
浮點數相對于定點數的優點是在長度一定的情況下,浮點數能夠表示更大的數據范圍;它的缺點是會引起精度問題。
在今后關于浮點數和定點數的應用中,大家要記住以下幾點:
1、浮點數存在誤差問題;
2、對貨幣等對精度敏感的數據,應該用定點數表示或存儲;
3、編程中,如果用到浮點數,要特別注意誤差問題,并盡量避免做浮點數比較;
4、要注意浮點數中一些特殊值的處理??梢钥纯催@個http://blog.csdn.net/lingmao5...
回答3:float(m,d) 中,m 代表總位數, d 代表小數點右邊的位數
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
相關文章:
1. mysql 為什么主鍵 id 和 pid 都市索引, id > 10 走索引 time > 10 不走索引?2. css - chrome下a標簽嵌套img 顯示會多個小箭頭?3. css3 - 純css實現點擊特效4. docker網絡端口映射,沒有方便點的操作方法么?5. javascript - Img.complete和img.onload判斷圖片加載完成有什么區別?6. vim - docker中新的ubuntu12.04鏡像,運行vi提示,找不到命名.7. mysql - 在不允許改動數據表的情況下,如何優化以varchar格式存儲的時間的比較?8. java中返回一個對象,和輸出對像的值,意義在哪兒9. javascript - 有適合開發手機端Html5網頁小游戲的前端框架嗎?10. css - 網頁div區塊 像蘋果一樣可左右滑動 手機與電腦
