服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Sql Server - sql server中的decimal或者numeric的精度问题

sql server中的decimal或者numeric的精度问题

2019-11-06 13:11mssql教程网 Sql Server

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

何谓精度:最多可以存储的十进制数字的总位数,包括小数点左边和右边的位数。该精度必须是从 1 到最大精度 38 之间的值。默认精度为 18。 
小数位数:小数点右边可以存储的十进制数字的最大位数。小数位数必须是从 0 到 p 之间的值。仅在指定精度后才可以指定小数位数。默认的小数位数为 0;因此,0 <= s <= p。最大存储大小基于精度而变化。 
在c sharp中调用传递SqlParameter参数时也需要制定参数的精度和小数的位数,如下面的例子声明一个精度为18小树位数为2的decimal类型参数: 

复制代码代码如下:


SqlParameter parm = new SqlParameter("@parmName", SqlDbType.Decimal); 
parm.Precision = 18; 
parm.Scale = 2;

延伸 · 阅读

精彩推荐