decimal是MySQL中存在的精准数据类型。MySQL中的数据类型有:float,double等非精准数据类型和decimal这种精准。区别:float,double等非精准类型,在DB中保存的是近似值。Decimal则以字符串的形式保存精确的原始数值。
扩展资料
对SQL Server而言,decimal和numeric视为相同的类型,它们可用来保存具有小数点而且数值确定的数值。它们不像float和real是用来保存近似值。此类型的列其声明方式为decima[(p[,s])]或numericl[(p[,s])]。其中p是此数值全部的位数,含小数部分但不包括小数点,s则是小数的位数。
p值称为此数值的精确度,例如:decimal(10,3)表示共有7位整数3位小数,此例的精确度为10位。此类型的列可保存的值范围为1038-1到-1038-1之间。其占用存储空间依精确度不同而不同,下表给出Decimal类型变量精确度和占用空间的关系。
直接给个例子。decimal(5,2) 其中 5为最多可以存储的十进制位数为5位,是小数点前后的位数总和。2表示小数点后面的位数。同理decimal(10,2)表示十进制为10为,小数点为2,例如11111111.36
,100.20是合法的值,而1234.56,总数为6位,为非法的数据值。有人说那存12345应该可以吧。事实证明是不行的。因为其精度是2,所以12345会被当做12345.00来处理,还是 非法的数据。 那么存储100.11111111111111呢?经测试,数据是可以存储的,但是会丢失精度(四舍五入),数据100.11会存储到数据库。
numeric和decimal同理。
两者没有区别。
1:decimal(numeric ) 同义,用于精确存储数值。decimal 数据类型最多可存储 38 个数字,所有数字都能够放到小数点的右边。
2:decimal 数据类型存储了一个准确(精确)的数字表达法;不存储值的近似值。
定义 decimal 的列、变量和参数的两种特性如下:
1:p 小数点左边和右边数字之和,不包括小数点.如 123.45,则 p=5,s=2。指定精度或对象能够控制的数字个数。
2:s 指定可放到小数点右边的小数位数或数字个数。这种128位高精度十进制数表示法通常用在财务计算中。要注意的是,在.NET环境中,计算该类型的值会有性能上的损失,因为它不是基本类型。
3:NUMERIC(P,S) P的默认值是:38 S的默认值是:-84~127。
4:NUMERIC(a,b)函数有两个参数,前面一个为总的位数,后面一个参数是小数点后的位数,例如NUMERIC(5,2)是总位数为5,小数点后为2位的数,也就是说这个字段的整数位最大是3位。
5:NUMERIC 数据类型使用标准、可变长度的内部格式来存储数字。
扩展资料:
1:Decimal为SQL Server、MySql等数据库的一种数据类型,不属于浮点数类型,可以在定义时划定整数部分以及小数部分的位数。
2:使用精确小数类型不仅能够保证数据计算更为精确,还可以节省储存空间,例如百分比使用decimal(4,2)即可。
3:存储数据范围是:-10^38~10^38-1 的固定精度和小数位的数字。一个decimal类型的数据占用了2~17个字节。
4:在C#里decimal表示 128 位数据类型。与double相比,decimal 类型具有更高的精度和更小的范围,它适合于财务和货币计算。
5:这两种数据类型是等效的。都有两个参数:p(精度)和s(小数位数)。p指定小数点左边和右边可以存储的十进制数字的最大个数,p必须是从 1到38之间的值。s指定小数点右边可以存储的十进制数字的最大个数,s必须是从0到p之间的值,默认小数位数是0。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)