[英]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,所以想象一下,如果您删除一个创建了分配的用户并修改了一个应该发生的情况,删除分配如果其他用户修改它会怎样,这将是继承人表中的空值.
所以
您需要使用FluentApi
将CascadeOnDelete
指定为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.