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

11

我正在使用EF Code First处理一个编写不佳的遗留数据库架构。 目前我正在映射POCO实体,并希望创建一个“地址”复合类型,并在存储街道地址信息的所有地方都使用它。 不幸的是,不是所有地址字段在数据库中的命名都相同(例如,一个表可能具有“Address1”,而另一个表将具有“Street1”,即使它们指的是同一件事情。

是否有一种基于给定实体创建自定义复杂类型映射的方法? 这个映射看起来像什么?


1
不要使用CTP5。安装一个名为4.1 RC的新版本 - http://www.microsoft.com/downloads/en/details.aspx?FamilyID=2dc5ddac-5a96-48b2-878d-b9f49d87569a&displaylang=en - Ladislav Mrnka
我以为CTP5是“最终版”?新版本是否修复了这个问题? - Ryan Eastabrook
不,CTP永远不会被视为最终版本。话虽如此,EF 4.1 RC似乎是在CTP5的基础上更多地修复了错误而非进行根本性的改变。 - Morteza Manavi
1个回答

14

是的,您可以使用流畅的 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");         
    }
}

3
要完全使用FluentAPI,您应该删除ComplexType注释并使用modelBuilder.ComplexType<Address>()方法。更新:既然这是一个旧帖子,我刚刚提交了一个编辑来执行此操作... 它正在等待审核。 - Ron DeFreitas

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接