MySQL 浮點(diǎn)型的精度范圍與四舍五入
問(wèn)題描述
問(wèn)題解答
回答1:因?yàn)椋阍趧?chuàng)建表的時(shí)候,指定的 f3 是 float(6,2) ,那這個(gè) 6 和 2 是什么意思?6 是數(shù)字總位數(shù)。2是小數(shù)點(diǎn)后只保留2位。所以會(huì)顯示成 9999.99 即總共 6 個(gè)9,小數(shù)后是 2 位
回答2:建議使用decimal,尤其是涉及到錢(qián)的問(wèn)題的時(shí)候,在mysql中float、double(或real)是浮點(diǎn)數(shù),decimal(或numberic)是定點(diǎn)數(shù)。
浮點(diǎn)數(shù)相對(duì)于定點(diǎn)數(shù)的優(yōu)點(diǎn)是在長(zhǎng)度一定的情況下,浮點(diǎn)數(shù)能夠表示更大的數(shù)據(jù)范圍;它的缺點(diǎn)是會(huì)引起精度問(wèn)題。
在今后關(guān)于浮點(diǎn)數(shù)和定點(diǎn)數(shù)的應(yīng)用中,大家要記住以下幾點(diǎn):
1、浮點(diǎn)數(shù)存在誤差問(wèn)題;
2、對(duì)貨幣等對(duì)精度敏感的數(shù)據(jù),應(yīng)該用定點(diǎn)數(shù)表示或存儲(chǔ);
3、編程中,如果用到浮點(diǎn)數(shù),要特別注意誤差問(wèn)題,并盡量避免做浮點(diǎn)數(shù)比較;
4、要注意浮點(diǎn)數(shù)中一些特殊值的處理。可以看看這個(gè)http://blog.csdn.net/lingmao5...
回答3:float(m,d) 中,m 代表總位數(shù), d 代表小數(shù)點(diǎn)右邊的位數(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解釋?zhuān)?/p>
不指定 m,d :按照 float 與 double 的范圍來(lái)取值
指定 m,d : 按照 m,d 的值來(lái)取,超過(guò)則四舍五入,不超過(guò)則補(bǔ) 0
相關(guān)文章:
1. mysql如何配置遠(yuǎn)程php外網(wǎng)鏈接數(shù)據(jù)庫(kù)2. 老師 我是一個(gè)沒(méi)有學(xué)過(guò)php語(yǔ)言的準(zhǔn)畢業(yè)生 我希望您能幫我一下3. mysql - eclispe無(wú)法打開(kāi)數(shù)據(jù)庫(kù)連接4. 導(dǎo)入數(shù)據(jù)庫(kù)不成功5. 數(shù)據(jù)庫(kù) - mysql中有沒(méi)查看數(shù)據(jù)大小的函數(shù)??6. PHP單例模式7. Mysql 關(guān)于 FOUND_ROWS() 和 ROW_COUNT() 函數(shù)8. mysql如何判斷數(shù)據(jù)不存在則插入呢?9. mysql無(wú)法刪除字段(錯(cuò)誤1091),但是對(duì)該字段設(shè)置主鍵后就可刪除,為什么?10. Mysql5.6以后,說(shuō) innode 的 select 性能不輸 myisam 了,為什么 ?
