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

c# – 当所有内容都设置为四位小数时,实体框架以小数点后两位进

发布时间:2020-12-15 05:38:02 所属栏目:百科 来源:网络整理
导读:我试图理解为什么实体框架4在EF模式模型和数据库中四舍五入到两位小数时,精度设置为4. 这是我的一个十进制字段的模式定义: 这是我的数据库定义 CREATE TABLE OrderItems(....[SellPrice] [decimal](19,4) NOT NULL,.... 当我在计算产品的售价后执行我的插入
我试图理解为什么实体框架4在EF模式模型和数据库中四舍五入到两位小数时,精度设置为4.

这是我的一个十进制字段的模式定义:

这是我的数据库定义

CREATE TABLE OrderItems(
....
[SellPrice] [decimal](19,4) NOT NULL,....

当我在计算产品的售价后执行我的插入查询时,我看到有足够的小数

MiniProfiler显示我的查询,它显示该值有小数

DECLARE ...
        @15 Decimal = '100,54347826086956521739130435',...

insert [dbo].[OrderItems](...,[SellPrice],...)
values (...,@15,....)
select [OrderItemId]
from [dbo].[OrderItems]
where @@ROWCOUNT > 0 and [OrderItemId] = scope_identity()

但是,当我查看Microsoft Sql Profiler时,SellPrice是四舍五入的

exec sp_executesql N'insert [dbo].[OrderItems](...,...)',...,@15=100.54,...'

我很难找到值被舍入的位置.

解决方法

我猜你的SQL数据类型应该是钱,而不是十进制,因为c#中的十进制与十进制SQL不同.特别是,如果您查看MSDN文档( http://msdn.microsoft.com/en-us/library/ms187746.aspx)中的TSQL十进制类型是状态;

In Transact-SQL statements,a constant with a decimal point is automatically converted into a numeric data value,using the minimum precision and scale necessary. For example,the constant 12.345 is converted into a numeric value with a precision of 5 and a scale of 3.

Converting from decimal or numeric to float or real can cause some loss of precision.

没有明确说明这是你的问题的原因,但我会好好猜测它是.你可能对money数据类型有更多好运,因为它是最等效的,如果你从现有数据库生成模型,这也是EF的默认值

(编辑:李大同)

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

    推荐文章
      热点阅读