繁体   English   中英

Entity Framework Core - 代码优先 - 两个外键 - 一张表

[英]Entity Framework Core - Code First - Two Foreign Keys - One Table

我正在使用 EF Core。 我希望我的基类保留对 CreateByUser 和 LastModifiedByUser 的引用。 不幸的是,我只能让它与一个外键一起工作。 当我尝试添加第二个外键时,出现此错误:

在表 'Assignments' 上引入 FOREIGN KEY 约束 'FK_Assignments_Users_LastModifiedByUserId' 可能会导致循环或多个级联路径。 指定 ON DELETE NO ACTION 或 ON UPDATE NO ACTION,或修改其他 FOREIGN KEY 约束。 无法创建约束或索引。 请参阅以前的错误。 请注意,我可以使用“Add-Migration”而不会出现任何错误,但是一旦我运行“Update-Database”就会出错。

以下是问题和错误的相关代码。

public abstract class DivBase
{
    [Key]
    public int Id { get; set; }

    [Required]
    public DateTimeOffset DateCreated { get; set; }

    public int CreatedByUserId { get; set; }

    [Required]
    public DateTimeOffset LastDateModified { get; set; }

    public int LastModifiedByUserId { get; set; }

    [ForeignKey("CreatedByUserId")]
    public DivUser CreatedByUser { get; set; }

    [ForeignKey("LastModifiedByUserId")]
    public DivUser LastModifiedByUser { get; set; }
}

public class DivUser
{
    [Key]
    public int Id { get; set; }

    [Required]
    [MaxLength(256)]
    public string Name { get; set; }

    [Required]
    [MaxLength(256)]
    public string Email { get; set; }
}

public class DivAssignment : DivBase, IDivEvent
{
    public DateTimeOffset StartDate { get; set; }
    public DateTimeOffset EndDate { get; set; }      
}

public interface IDivEvent
{
    [Required]
    public DateTimeOffset StartDate { get; set; }

    [Required]
    public DateTimeOffset EndDate { get; set; }
}

此外,如果我将其中一个属性设为可空,它将编译,但我担心这会在以后引起问题。

显然,您对同一row中的同一张表有 2 Fk s,所以想象一下,如果您删除一个创建了分配的用户并修改了一个应该发生的情况,删除分配如果其他用户修改它会怎样,这将是继承人表中的空值.

所以

您需要使用FluentApiCascadeOnDelete指定为false

ApplicationContext

protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            modelBuilder.Entity<DivAssignment>()
                .HasRequired(c => c.CreatedByUser)
                .WithMany(u => u.CreatedDivAssignments)
                .HasForeignKey(c => c.CreatedByUserId)
                .WillCascadeOnDelete(false);

            modelBuilder.Entity<DivAssignment>()
                .HasRequired(c => c.LastModifiedByUser)
                .WithMany(u => u.ModifiedDivAssignments)
                .HasForeignKey(c => c.LastModifiedByUserId)
                .WillCascadeOnDelete(false);
        }

然后add-migration然后update-database

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

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