簡體   English   中英

實體框架4.1代碼第一外鍵ID

[英]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但是另一個沒有暴露的PersonPerson和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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM