这是我现有的模特。
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&#34 ;.冲突发生在数据库中 " TestMigrations",table" dbo.Teams",column' Id'。
我试图弄清楚如何在Teams表上添加一行,以便现有的学院记录可以引用它。或者有更好的方法来处理这个错误吗?
答案 0 :(得分:0)
我认为这个问题是因为您正在以这种方式配置一对多关系:
modelbuilder.Entity<Academy>()
.HasRequired(a=>a.Team)
.WithMany()
.HasForeignKey(a=>a.TeamId);
如果您以这种方式配置了关系,那么当您要保存新的时,必须设置Team
导航属性(或TeamID
FK属性) 您的数据库中Academy
。由于你已经在数据库中有一些没有联合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);