如何解决EF6 十进制到 FLOAT(126) 精度,35 位
我在 Oracle 11g2 中使用实体框架 6。
我的数据库中有一个 FLOAT(126)
列(不允许修改),我想将此值映射到我的实体。
所以我使用了 decimal
,并且在我的构建器中,我定义了一个精度 HasPrecision(126,35)
。
我的表的一行包含此值 -0,00000000000000000053175155024474241
。当我尝试检索该行时,出现 Invalid cast
异常。
如何避免这种异常?
我尝试过的:
编辑
这是我的实体:
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 举报,一经查实,本站将立刻删除。