[英]Entity Framework 4.1 Code First Foreign Key Id's
我有兩個實體引用了一對多。 當實體框架創建表時,它會創建兩個外鍵,一個用於我用Fluent接口指定的鍵,另一個用於ICollection。 如何擺脫重復的外鍵?
public class Person
{
public long RecordId { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public string Email { get; set; }
public string Username { get; set; }
public long DepartmentId { get; set; }
public virtual Department Department { get; set; }
}
public class Department
{
public long RecordId { get; set; }
public string Name { get; set; }
public virtual ICollection<Person> People { get; set; }
}
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Entity<Person>()
.HasRequired(p => p.Department)
.WithMany()
.HasForeignKey(p => p.DepartmentId)
.WillCascadeOnDelete(false);
}
謝謝!
您必須明確指定關聯的多端:
modelBuilder.Entity<Person>()
.HasRequired(p => p.Department)
.WithMany(d => d.People)
.HasForeignKey(p => p.DepartmentId)
.WillCascadeOnDelete(false);
否則,EF將假定有兩個關聯:一個沒有在Department
暴露的Department
,如在Fluent代碼中定義的Person
類中的外鍵DepartmentId
和導航屬性Department
- 以及另一個屬於暴露導航屬性的關聯People
但是另一個沒有暴露的Person
在Person
和EF自動創建的外鍵。 這是您在數據庫中看到的另一個鍵。
默認的Code First約定檢測您的DepartmentId外鍵,因為它是傳統的。 我認為你應該刪除Fluent定義:
modelBuilder.Entity<Person>()
.HasRequired(p => p.Department)
.WithMany()
.WillCascadeOnDelete(false);
最好的方法是從Person類中刪除departmentid屬性並添加以下語句。 MapKey將使用您指定的名稱創建外鍵列
modelBuilder.Entity<Person>().HasRequired(p => p.Department)
.WithMany().Map(x=>x.MapKey("DepartmentId"))
.WillCascadeOnDelete(false);
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.