微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

EF6 十进制到 FLOAT(126) 精度,35 位

如何解决EF6 十进制到 FLOAT(126) 精度,35 位

我在 Oracle 11g2 中使用实体框架 6。

我的数据库中有一个 FLOAT(126) 列(不允许修改),我想将此值映射到我的实体。

所以我使用了 decimal,并且在我的构建器中,我定义了一个精度 HasPrecision(126,35)

我的表的一行包含此值 -0,00000000000000000053175155024474241。当我尝试检索该行时,出现 Invalid cast 异常。

如何避免这种异常?

我尝试过的:

  • 截断删除 7 位数字 (-0,0000000000000000005317515502) 的值,它可以工作。但这不是解决方案。
  • 去掉 - 标志,但仍然不起作用

编辑

这是我的实体:

public class MyEntity
{
     ...
     public decimal? MyProperty { get; set; }
}

这是我的建造者:

protected override void BuildModel(EntityTypeConfiguration<MyEntity> modelBuilder)
{
     ...
     modelBuilder.Property(e => e.MyProperty)
                 .HasColumnName("MY_PROPERTY")
                 .HasColumnType("FLOAT")
                 .HasPrecision(126,32)
                 .IsOptional();
}

这是我的表的 sql :

CREATE TABLE "MY_TABLE"
(
    ...
    "MY_PROPERTY" FLOAT(126) DEFAULT 0
)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。