繁体   English   中英

EF:ALTER TABLE语句与FOREIGN KEY约束冲突

[英]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表中的外键SeverityLevelSeverity表中的主键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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM