问题 实体框架4 - 自定义复杂类型映射


我有一个写得不好的遗留数据库模式,我正在通过EF Code First工作。我目前正在映射POCO实体,并希望创建一个“地址”复杂类型,并在存储街道地址信息的任何地方使用它。不幸的是,并非所有的地址字段在数据库中都被命名为相同(即,一个表可能具有“Address1”,而另一个表将具有“Street1”,即使它们引用相同的东西。

有没有办法根据给定的实体为复杂类型创建自定义映射?那个映射是什么样的?


12434
2018-03-16 07:11


起源

不要使用CTP5。安装名为4.1 RC的新版本 - microsoft.com/downloads/en/... - Ladislav Mrnka
我以为CTP5是“最终的”?新版本是否解决了这个问题? - Ryan Eastabrook
不,CTP永远不会被认为是最终版本。也就是说,EF 4.1 RC似乎是一个比CTP5的基本改变更多的错误修复版本。 - Morteza Manavi


答案:


是的,您可以使用流畅的API实现这一目标。这是一个例子:

public class User
{
    public int UserId { get; set; }   
    public Address Address { get; set; }
}

public class Customer
{
    public int CustomerId { get; set; }   
    public Address Address { get; set; }
}

[ComplexType]
public class Address
{
    public string Street { get; set; }    
    public string City { get; set; }
}

public class Context : DbContext
{    
    public DbSet<User> Users { get; set; }
    public DbSet<Customer> Customers { get; set; }

    protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {       
        modelBuilder.Entity<User>().Property(u => u.Address.Street)
                                   .HasColumnName("UserStreet");

        modelBuilder.Entity<Customer>().Property(u => u.Address.Street)
                                       .HasColumnName("CustomerStreet");         
    }
}

14
2018-03-16 16:16



要完全保留在FluentAPI中,您应该删除ComplexType注释并使用modelBuilder.ComplexType <Address>();更新:刚刚提交了一个编辑来执行此操作,因为这是一个旧帖子....它正在等待 - Ron DeFreitas