我试图理解为什么实体框架 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](..., [SellPrice], ...)
values (..., @15, ...)',
...,@15=100.54,...'
我很难找到四舍五入的值。