【问题标题】:EF6 code-first getting a undesired referenceIDEF6 代码首先获取不需要的 referenceID
【发布时间】:2017-06-15 02:15:56
【问题描述】:

由于某种原因,在生成我的数据库时,我得到了一个不必要的外键,我不知道如何停止它。

复制此问题的示例如下:

public class Person
{
   public int PersonId { get; set; }
   public string Name { get; set; }
   public virtual ICollection<PersonRelationships> PersonRelationships { get; set; }
}

public class PersonRelationship
{
   public int PersonRelationshipId { get; set; }
   public Person PersonOne { get; set; }
   public Person PersonTwo { get; set; }
   public PersonRelationshipType RelationshipType { get; set; }
}

public enum PersonRelationshipType
{
   Mother = 1,
   Father = 2,
   Sibling = 3
}

在我的DbContext 我有:

DbSet<Person> People { get; set; }

现在奇怪的是,当我使用代码优先迁移生成模型时,PeopleRelationships 表将获得 PersonOne_PersonIdPersonTwo_PersonId 的预期外键,但随后还会出现意外的 Person_PersonId。我认为这与人的参考有关,但我不确定如何摆脱它,因为我需要那个参考。

我错过了什么?

【问题讨论】:

  • 这就是史蒂夫的答案。逆属性修复了它。太棒了,谢谢!
  • 您应该将其移至答案,以便我将其标记为答案!
  • 不用担心,一点点努力。如果您正确连接 FK,流畅的方式应该也可以工作。

标签: .net entity-framework ef-code-first entity-framework-6 ef-code-first-mapping


【解决方案1】:

根据 Steve Greene 对原始帖子的评论,答案是使用 [InverseProperty("PropertyName")] 属性标记逆属性。

谢谢史蒂夫!

【讨论】:

    【解决方案2】:

    同一张表有两个外键。我认为您需要使用 DbModelBuilder 来定义您的外键并编辑 Person 模型,如下所示。然后你就可以更新你的数据库了。

    public class Person
    {
       public int PersonId { get; set; }
       public string Name { get; set; }
       public virtual ICollection<PersonRelationships> PersonOneRelationships { get; set; }
       public virtual ICollection<PersonRelationships> PersonTwoRelationships { get; set; }
    }
    
    protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            modelBuilder.Entity<PersonRelationship>()
                        .HasRequired(m => m.PersonOne )
                        .WithMany(t => t.PersonOneRelationships)
                        .HasForeignKey(m => m.PersonOneId)
                        .WillCascadeOnDelete(false);
    
            modelBuilder.Entity<PersonRelationship>()
                        .HasRequired(m => m.PersonTwo )
                        .WithMany(t => t.PersonTwoRelationships)
                        .HasForeignKey(m => m.PersonTwoId)
                        .WillCascadeOnDelete(false);
        }
    

    【讨论】:

    • 谢谢哈桑,当我这样做时,实际上是添加了一个额外的外键而不是删除第一个。所以现在它有两个额外的 person_personid 列它试图保存
    • 它没有。这使问题变得更糟。
    • 每次我们向 Person 添加一个新的 ICollection 时,它都会向关系表添加一个新的 person_id FK。它没有意识到它拥有的人对象是实际的引用
    • 你可以尝试用这种方式重新创建这两个表吗
    • 我手动这样做了,当我尝试保存它时抛出一个异常,该表不包含列 person_id
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多