2

我正在使用 EF5 Code First,我正在尝试存储一个 IPAddress 对象。如果您尝试直接执行此操作,EF 会将其存储为两列,FIELDNAME_Address 和 FIELDNAME_Scope。不幸的是,这不足以存储 IPv4 地址,因为访问 ScopeId 会引发异常(请参阅C# The mapped operation is not supported for the type of object reference)。

我想做的是定义一个类型如何在 EF 中映射,但我不确定如何做到这一点,或者它的术语是什么。这将是最干净的解决方案,让我的 POCO 保持纯净:

public class TestRecord 
{
    public int Id { get; set; }
    public IPAddress IP { get; set; }
}

使用 OnModelCreating 中的内容来描述如何序列化 + 反序列化 IPAddress 对象。

我考虑过的另一个选择是使用包装字段:

public class TestRecord 
{
    public int Id { get; set; }
    public long value_ip { get; set; }
    [NotMapped]
    public IPAddress IP 
    { 
        get { return value_ip.ToIPAddress(); }
        set { value_ip = value.ToLong(); 
    } 
} 

不幸的是,这要么要求该字段是公共的,要么需要一些表达式来映射私有字段。无论哪种方式,它都不如能够在上下文级别定义“这是您存储 IPAddress 类型的方式”那么干净,这是我的首选解决方案。

4

1 回答 1

2

EF不支持序列化/反序列化、自定义类型映射或映射类型转换。您必须使用复杂类型并以某种方式在该类型中处理它,或者您必须使用包装字段(复杂类型也将使用包装字段)。

于 2012-08-21T10:51:51.010 回答