好吧,我有一对多的相关模型:
public class Parent
{
public int Id { get; set; }
public string Name { get; set; }
public ICollection<Child> Children { get; set; }
}
public class Child
{
public int Id { get; set; }
public string ChildName { get; set; }
}
我想要做的是Parent.Children
从数据库中清除并删除相关的子实体。我已经尝试过:
数据库上下文类:
modelBuilder.Entity<Parent>()
.HasMany(p => p.Children)
.WithOptional()
.WillCascadeOnDelete(true);
这很好用,但是Parent_Id = null
当我这样做时,我的数据库中仍然有冗余记录和字段
parent.Children.Clear();
repository.InsertOrUpdate(parent);
在我的存储库类中。同样的行为是当我这样做时:
modelBuilder.Entity<Parent>()
.HasMany(pr => pr.Children)
.WithOptional(ri => ri.Parent)
.WillCascadeOnDelete(true);
在类中具有附加Parent
属性Child
public class Child
{
...
public Parent Parent { get; set; }
...
}
或者当我这样做时
modelBuilder.Entity<Child>()
.HasOptional(p => p.Parent)
.WithMany(p => p.Children)
.HasForeignKey(p => p.Parent_Id)
.WillCascadeOnDelete(true);
Child
在类中有额外的 Parent_Id 属性
public class Child
{
...
public int Parent_Id { get; set; }
...
}
那么,如何正确配置级联删除呢?或者我应该如何删除那些子实体?我认为这是一项临时任务,但我只是错过了一些东西。