decimal和numeric区别是什么?

如题所述

两者没有区别。

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。

温馨提示:答案为网友推荐,仅供参考