首页 文章

使用codefirst迁移实体框架6将外键添加到模型和新模型

提问于
浏览
1

这是我现有的模型 .

public class Academy
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public string Address { get; set; }
        public int TeamId { get; set; }

        public virtual Team Team { get; set; }
    }

这是新模式 .

public class Team
{
    public int Id { get; set; }
    public string Name { get; set; }
}

这是生成的迁移脚本

namespace TestMigrations.Domain.Migrations
{
    using System;
    using System.Data.Entity.Migrations;

    public partial class teamNew : DbMigration
    {
        public override void Up()
        {
            CreateTable(
                "dbo.Teams",
                c => new
                    {
                        Id = c.Int(nullable: false, identity: true),
                        Name = c.String(),
                    })
                .PrimaryKey(t => t.Id);

            AddColumn("dbo.Academies", "TeamId", c => c.Int(nullable: false));
            CreateIndex("dbo.Academies", "TeamId");
            AddForeignKey("dbo.Academies", "TeamId", "dbo.Teams", "Id", cascadeDelete: true);
        }

        public override void Down()
        {
            DropForeignKey("dbo.Academies", "TeamId", "dbo.Teams");
            DropIndex("dbo.Academies", new[] { "TeamId" });
            DropColumn("dbo.Academies", "TeamId");
            DropTable("dbo.Teams");
        }
    }
}

学院现有记录,这是出现的错误:

ALTER TABLE语句与FOREIGN KEY约束“FK_dbo.Academies_dbo.Teams_TeamId”冲突 . 冲突发生在数据库“TestMigrations”,表“dbo.Teams”,列“Id”中 .

我正在试图弄清楚如何在Teams表上添加一行,以便现有的学院记录可以引用它 . 或者有更好的方法来处理这个错误?

1 回答

  • 0

    我认为这个问题是因为您正在以这种方式配置一对多关系:

    modelbuilder.Entity<Academy>()
                .HasRequired(a=>a.Team)
                .WithMany()
                .HasForeignKey(a=>a.TeamId);
    

    如果以这种方式配置了关系,则在要在数据库中保存新的 Academy 时,必须设置 Team 导航属性(或 TeamID FK属性) . 由于你已经在数据库中已经有一些没有联合 Team 的学院,EF会抛出你的异常 . 尝试以这种方式配置该关系:

    public class Academy
    {
        //...
        public int? TeamId { get; set; }
    
        public virtual Team Team { get; set; }
    }
    

    然后,在您的上下文的 OnModelCreating 方法中添加以下内容:

    modelbuilder.Entity<Academy>()
                 .HasOptional(a=>a.Team)
                 .WithMany()
                 .HasForeignKey(a=>a.TeamId);
    

相关问题