当所有内容都设置为四位小数时,实体框架以小数点后两位舍入

Pie*_*ant 5 c# sql-server-2008-r2 entity-framework-4

我试图理解为什么实体框架4在EF模式模型和数据库中四舍五入到两位小数时,精度设置为4.

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

SellPrice指定比例为19,4

这是我的数据库定义

CREATE TABLE OrderItems(
....
[SellPrice] [decimal](19, 4) NOT NULL,
....
Run Code Online (Sandbox Code Playgroud)

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

SellPrice显示许多小数

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

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

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

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

exec sp_executesql N'insert [dbo].[OrderItems](..., [SellPrice], ...)
values (..., @15, ...)',
...,@15=100.54,...'
Run Code Online (Sandbox Code Playgroud)

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

Dis*_*nky 3

据猜测,我想说你的 SQL 数据类型应该是money,而不是decimalc decimal# 中的那样与 SQL 不同。特别是,如果您查看 MSDN 文档 ( http://msdn.microsoft.com/en-us/library/ms187746.aspx),TSQL类型是 states;decimaldecimal

在 Transact-SQL 语句中,带有小数点的常量会使用必要的最小精度和小数位数自动转换为数值数据值。例如,常数 12.345 被转换为精度为 5、小数位数为 3 的数值。

从十进制或数值转换为浮点或实数可能会导致精度损失。

没有明确指出这是导致您的问题的原因,但我猜测确实如此。您可能会更幸运地使用该money数据类型,因为这是最等效的,并且如果您从现有数据库生成模型,这也是 EF 默认的数据类型

  • 我尝试将字段设置为金钱。这是行不通的。我还尝试做另一个实体模型,只是为了看看它们如何映射,它确实显示精度为 19,比例为 4,但 Sql Profiler 仍然显示 Decimal(19,2)。一定是在别的地方,但我找不到在哪里。 (2认同)