MySQL浮點數和定點數


MySQL 分為兩種方式:浮點數和定點數。浮點數包括 float(單精度)和 double(雙精度),而定點數則只有 decimal 一種表示。
定點數在 MySQL 內部以字符串形式存放,比浮點數更精確,適合用來表示貨幣等精度高的數據。

浮點數和定點數都可以用類型名稱后加“(M,D)”的方式來進行表示,“(M,D)”表示該值一共顯示 M 位數字(整數位+小數位),其中 D 位位於小數點后面,M 和 D 又稱為精度和標度。
例如,定義為 float(7,4)的一個列可以顯示為-999.9999。
MySQL 保存值時進行四舍五入,因此如果在 float(7,4)列內插入 999.00009,近似結果是 999.0001。
值得注意的是,浮點數后面跟“(M,D)”的用法是非標准用法,如果要用於數據庫的遷移,則最好不要這么使用。
float 和 double 在不指定精度時,默認會按照實際的精度(由實際的硬件和操作系統決定)來顯示,
而 decimal 在不指定精度時,默認的整數位為 10,默認的小數位為 0。

 

CREATE TABLE `t1` (
`id1` float(5,2) default NULL,
`id2` double(5,2) default NULL,
`id3` decimal(5,2) default NULL
)


insert into t1 values(1.23,1.23,1.23);

insert into t1 values(1.234,1.234,1.23);

insert into t1 values(1.234,1.234,1.234);


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM