我首先使用的是 EF 4.1 RC 代码。我在联结表 Friends 中使用复合 PK 的多对多关系。我们明确需要一个单独的 Friends 类(不要问),它代表我们的联结表。我们的目标是能够控制用户实体的删除过程。请在阅读其余内容之前阅读此内容:http: //mocella.blogspot.com/2010/01/entity-framework-v4-object-graph.html。因此,我们设法创建了复合 PK,但这破坏了我们对集合的映射。问题是如何映射 FriendsCol?
public class User
{
public int UserId { get; set; }
public string Name { get; set; }
public virtual ICollecion<Friends> FriendsCol { get; set; }
}
public class Friends
{
public int User1Id { get; set; }
public int User2Id { get; set; }
public User User1 { get; set; }
public User User2 { get; set; }
}
有一个复合键映射
public class FriendsMap : EntityTypeConfiguration<Friends>
{
HasKey(m => new { m.userId1 , m.userId2 });
//this.HasRequired(x => x.User1)
//.WithMany()
//.HasForeignKey(x => x.User1Id)
//.WillCascadeOnDelete(false);
//this.HasRequired(x => x.User2)
// .WithMany()
// .HasForeignKey(x => x.User2Id)
// .WillCascadeOnDelete(false);
}
public class UserMap : EntityTypeConfiguration<UserNew>
{
public UserMap()
{
ToTable("users");
Property(user => user.Name).HasColumnName("name");
// HasMany<Friends>(user => user.FriendsCol).WithMany();
}
}