[英]The ALTER TABLE statement conflicted with the FOREIGN KEY constraint
[英]EF: The ALTER TABLE statement conflicted with the FOREIGN KEY constraint
我正在尝试在要创建的新表上使用update-database
命令,并且提供了以下消息:
ALTER TABLE语句与FOREIGN KEY约束“ FK_dbo.ActivityLog_dbo.Severity_SeverityLevel”冲突。 数据库“ APGameLogs”的表“ dbo.Severity”的“级别”列中发生了冲突。
难道我做错了什么? 这是因为ActivityLog
表中的外键SeverityLevel
与Severity
表中的主键Level
是不同的名称吗?
我的实体如下:
public class ActivityLog
{
public int ActivityLogId { get; set; }
[Required]
public int ActionLogId { get; set; }
[Required]
public int ActivityId { get; set; }
[Range(0, 7)]
public int SeverityLevel { get; set; }
[Required]
public DateTime ActivityDate { get; set; }
// Navigation properties
public ActionLog ActionLog { get; set; }
public Activity Activity { get; set; }
[ForeignKey("SeverityLevel")]
public Severity Severity { get; set; }
}
public class Severity
{
public Severity()
{
this.ActivityLogs = new HashSet<ActivityLog>();
}
[Key]
[Range(0,7)]
public int Level { get; set; }
[MaxLength(50)]
[Required]
public string Name { get; set; }
[MaxLength(256)]
public string Description { get; set; }
// Navigation properties
public virtual ICollection<ActivityLog> ActivityLogs { get; set; }
}
我的迁移如下
public partial class Severity : DbMigration
{
public override void Up()
{
CreateTable(
"dbo.Severity",
c => new
{
Level = c.Int(nullable: false, identity: true),
Name = c.String(nullable: false, maxLength: 50),
Description = c.String(maxLength: 256),
})
.PrimaryKey(t => t.Level)
.Index(t => t.Name, unique: true, name: "UK_Severity_Name");
AddColumn("dbo.ActivityLog", "SeverityLevel", c => c.Int(nullable: false));
CreateIndex("dbo.ActivityLog", "SeverityLevel");
AddForeignKey("dbo.ActivityLog", "SeverityLevel", "dbo.Severity", "Level");
}
public override void Down()
{
DropForeignKey("dbo.ActivityLog", "SeverityLevel", "dbo.Severity");
DropIndex("dbo.Severity", "UK_Severity_Name");
DropIndex("dbo.ActivityLog", new[] { "SeverityLevel" });
DropColumn("dbo.ActivityLog", "SeverityLevel");
DropTable("dbo.Severity");
}
}
**这是程序包管理器在失败时正在做的事情:**
Applying explicit migration: 201510161347096_Severity.
CREATE TABLE [dbo].[Severity] (
[Level] [int] NOT NULL IDENTITY,
[Name] [nvarchar](50) NOT NULL,
[Description] [nvarchar](256),
CONSTRAINT [PK_dbo.Severity] PRIMARY KEY ([Level])
)
CREATE UNIQUE INDEX [UK_Severity_Name] ON [dbo].[Severity]([Name])
ALTER TABLE [dbo].[ActivityLog] ADD [SeverityLevel] [int] NOT NULL DEFAULT 0
CREATE INDEX [IX_SeverityLevel] ON [dbo].[ActivityLog]([SeverityLevel])
ALTER TABLE [dbo].[ActivityLog] ADD CONSTRAINT [FK_dbo.ActivityLog_dbo.Severity_SeverityLevel] FOREIGN KEY ([SeverityLevel]) REFERENCES [dbo].[Severity] ([Level])
您正在为ActivityLog
[SeverityLevel]
添加默认0值。您应确保在Serverity
表中具有[Level]
0
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.