One - One Code All

Blog Content

mysql数据类型decimal类型详解

MySQL   2009-05-02 20:19:03

float:浮点型,含字节数为4,32bit,数值范围为-3.4E38~3.4E38(7个有效位)
double:双精度实型,含字节数为8,64bit数值范围-1.7E308~1.7E308(15个有效位)
decimal:数字型,128bit,不存在精度损失,常用于银行帐目计算。(28个有效位)

按存储的范围进行排序
float(real)
double
decimal(numeric)

decimal的详细介绍

decimal(M,D)

参数说明
M指定指定小数点左边和右边可以存储的十进制数字的最大个数,M是值的最大精度数位,1-65。
D指定小数点右边可以存储的十进制数字的最大个数。小数位数必须是从 0 到 a之间的值。默认小数位数是 0。D是小数点右侧数位0-30

官方参考:https://dev.mysql.com/doc/refman/5.7/en/precision-math-decimal-characteristics.html


备注
DECIMAL数据类型用于要求非常高的精确度的计算中。

DECIMAL(M,D)中D值的是小数部分的位数,若插入的值未指定小数部分或者小数部分不足D位则会自动补到D位小数,若插入的值小数部分超过了D位则会发生截断,截取前D位小数(四舍五入截取)。M值得是整数部分加小数部分的总长度,也即插入的数字整数部分不能超过M-D位,否则不能成功插入,会报超出范围的错误。

超出精度范围的数会被强制进位并只显示数据类型定义的格式。


总结
数值存储范围越小的精度越高,存储数值范围越大,精度就越不准确,如果存储正常金额的情况下,使用money,好处在于可以存储不指定的小数点位数的数值,比较真实。如果对于既要求精度,又固定小数点位数的数值存储,采用decimal(numeric),优点在于可以自定义小数点位数,精度高。如特殊情况,如数值范围巨大只能用float(real)类型了,此类型一般不提倡使用。


上一篇:mysql去掉重复值
下一篇:MySQL 添加列,修改列,删除列,alter table

The minute you think of giving up, think of the reason why you held on so long.