审题错了...
简单写下区别:
float:浮点型,含字节数为4,32bit,数值范围为-3.4E38~3.4E38(7个有效位)
double:双精度实型,含字节数为8,64bit数值范围-1.7E308~1.7E308(15个有效位)
decimal:数字型,128bit,不存在精度损失,常用于银行帐目计算。(28个有效位)
numberic === decimal
float f = 345.98756f//结果显示为345.9876,只显示7个有效位,对最后一位数四舍五入。
double d=345.975423578631442d//结果显示为345.975423578631,只显示15个有效位,对最后一位四舍五入。
注:float和double的相乘 *** 作,数字溢出不会报错,会有精度的损失。
decimal dd=345.545454879.....//可以支持28位,对最后一位四舍五入。
注:当对decimal类型进行 *** 作时,数值会因溢出而报错。
DECIMAL和NUMERIC类型在MySQL中视为相同的类型。它们用于保存必须为确切精度的值,例如货币数据。当声明该类型的列时,可以(并且通常要)指定精度和标度;例如:DECIMAL(10,2)
在该例子中,10是精度,2是标度。精度表示保存值的主要位数,标度表示小数点后面可以保存的位数
1、数据库中表示小数。
2、所以java使用float接受定义,是最合适的。
3、还有一种Double类型,不过这种类型是使用小数很位数很多的时候使用它最后合适。
Decimal为SQL Server、MySql等数据库的一种数据类型,不属于浮点数类型,可以再定义时划定整数部份以及小数部分的位数。使用精确小数类型不仅能够保证数据计算更为精确,还可以节省储存空间,例如百分比使用decimal(4,2)即可。存储数据范围是,-10^38~10^38 的固定精度和小数位的数字。一个decimal类型的数据占用了2~17个字节。decimal 的 SQL-92 同义字是 dec 和 dec(p, s),numeric 的功能相当於 decimal。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)