Entity framework 4 实体框架4-自定义复杂类型映射
我有一个写得很差的遗留数据库模式,我首先通过EF代码处理它。我目前正在映射POCO实体,并希望创建一个“地址”复杂类型,并在存储街道地址信息的任何地方使用它。不幸的是,并非所有的地址字段在数据库中的名称都相同(即,一个表可能有“Address1”,而另一个表可能有“Street1”,即使它们引用相同的内容Entity framework 4 实体框架4-自定义复杂类型映射,entity-framework-4,ef-code-first,entity-framework-4.1,Entity Framework 4,Ef Code First,Entity Framework 4.1,我有一个写得很差的遗留数据库模式,我首先通过EF代码处理它。我目前正在映射POCO实体,并希望创建一个“地址”复杂类型,并在存储街道地址信息的任何地方使用它。不幸的是,并非所有的地址字段在数据库中的名称都相同(即,一个表可能有“Address1”,而另一个表可能有“Street1”,即使它们引用相同的内容 有没有一种方法可以基于给定实体为复杂类型创建自定义映射?该映射是什么样子的?是的,您可以使用fluent API实现这一点。以下是一个示例: public class User { p
有没有一种方法可以基于给定实体为复杂类型创建自定义映射?该映射是什么样子的?是的,您可以使用fluent 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");
}
}
公共类用户
{
public int UserId{get;set;}
公共广播地址{get;set;}
}
公共类客户
{
public int CustomerId{get;set;}
公共广播地址{get;set;}
}
[复合类型]
公共课堂演讲
{
公共字符串Street{get;set;}
公共字符串City{get;set;}
}
公共类上下文:DbContext
{
公共数据库集用户{get;set;}
公共数据库集客户{get;set;}
模型创建时受保护的覆盖无效(DbModelBuilder modelBuilder)
{
modelBuilder.Entity()属性(u=>u.Address.Street)
.HasColumnName(“用户街”);
modelBuilder.Entity()属性(u=>u.Address.Street)
.HasColumnName(“CustomerStreet”);
}
}
不要使用CTP5。安装一个名为4.1 RC的新版本-我认为CTP5是“最终版本”?新版本解决了这个问题吗?不,CTPs从未被视为最终版本。也就是说,EF 4.1 RC似乎是一个更能修复错误的版本,而不是CTP5的根本性更改。要完全保留在FluentAPI中,您应该删除ComplexType注释并使用modelBuilder.ComplexType();更新:刚刚提交了一个编辑,因为这是一篇旧文章…它正在等待