加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

.NET Decimal =什么在SQL中?

发布时间:2020-12-12 06:57:29 所属栏目:MsSql教程 来源:网络整理
导读:SQL中最好的数据类型是什么代表Decimal in .NET? 我们要存储十进制数字,最多可以存在9位小数位精度,并且要避免前端的四舍五入错误等。 阅读数据类型,在.NET中使用Decimal是最好的选择,因为您不会得到四舍五入的错误,尽管它比Double更慢。 我们希望通过
SQL中最好的数据类型是什么代表Decimal in .NET?

我们要存储十进制数字,最多可以存在9位小数位精度,并且要避免前端的四舍五入错误等。

阅读数据类型,在.NET中使用Decimal是最好的选择,因为您不会得到四舍五入的错误,尽管它比Double更慢。

我们希望通过下载到DB,并希望通过图层移动数据时需要最小的转换问题。有什么建议么?

解决方法

所以我们在SQL Server上做了一些测试。它看起来像sql类型十进制不能完全存储任何.net十进制。

SQL Server可以存储高达38 decimal digits long的数字。这是左边和右边小数位数的总和。您设置了一个“Scale”,它告诉SQL服务器为小数位右侧的数字保留多少个十进制数字。如果您设置了一个缩放比例,那么这将缩小到小数点左边的位数。 (精度 – 刻度=小数位左侧的小数位数)

.NET可以表示小数点右侧的最多28位数字,而在左侧可以显示29位数字。这将需要SQL Server中的精度为57,但最大可用数为38。

所以如果你想要获得尽可能多的精度,你的数字足够小,那么你可以这样做:

decimal(38,28)

那会留下你左边的10位数字,右边是28位数字。因此,任何大于9999999999的数字都无法表示,但是在进行货币类型交易时不会丢失精度。

另一方面,如果你的数字很大,你可以用这个声明存储他们:

decimal(38,9)

这将让您存储.net Decimal可以存储的最大数字,这是29位数字长。它会给你带来精确的8位十进制数字。

如果没有一个这样听起来很吸引人,那么你可以将它们存储为varchar。这将允许您保存任何.net十进制,但它不会让您在SQL中对其执行任何计算。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读