5

我试图理解为什么实体框架 4 在 EF 模式模型和数据库中都将精度设置为 4 时舍入到小数点后两位。

这是我对十进制字段之一的架构定义:

SellPrice 指定比例为 19,4

这是我的数据库定义

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

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

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()

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

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

我很难找到四舍五入的值。

4

1 回答 1

3

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

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

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

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

于 2013-02-19T20:32:58.913 回答