sql server中decimal或numeric的精度问题

发布时间:2020-03-20编辑:脚本学堂
本文介绍下,有关sql server中decimal或numeric的精度问题,在sql server中定义列的数据类型decimal时需要制定其精度和小数位数。有需要的朋友参考下。

在sql server中定义列的数据类型为decimal时,需要制定其精度和小数位数。

精度:
 

最多可以存储的十进制数字的总位数,包括小数点左边和右边的位数。
该精度必须是从 1 到最大精度 38 之间的值。
默认精度为 18。

小数位数:
 

小数点右边可以存储的十进制数字的最大位数。
小数位数必须是从 0 到 p 之间的值。仅在指定精度后才可以指定小数位数。
默认的小数位数为 0;因此,0 <= s <= p。最大存储大小基于精度而变化。

在c#中调用传递SqlParameter参数时,也需要制定参数的精度和小数的位数。

例子,声明一个精度为18小树位数为2的decimal类型参数:
 

复制代码 代码示例:
SqlParameter parm = new SqlParameter("@parmName", SqlDbType.Decimal);
parm.Precision = 18;
parm.Scale = 2;