c# - 如何删除 EF 代码优先数据库中的子一对多相关记录?

标签 c# entity-framework code-first

好吧,我有一对多相关模型:

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);

Child 类中有额外的 Parent 属性

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; }
     ...
}

那么,如何正确配置级联删除呢?或者我应该如何删除那些子实体?我认为这是一项临时任务,但我只是遗漏了一些东西。

最佳答案

在 EF6 中,一种更快的操作方式是...

 context.Children.RemoveRange(parent.Children)

关于c# - 如何删除 EF 代码优先数据库中的子一对多相关记录?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16654828/

相关文章:

C# CallerMemberName 不能在 args 中使用动态?

c# - ASP.NET Core MVC 动态返回不是驼峰式

c# - 简单的 MVC 评论审核

linq - 如何转换此 linq 表达式?

entity-framework - Entity Framework 4 Code-First优缺点

c# - 如何检查谓词表达式是否已更改?

c# - 使 Propertygrid 在运行时显示绑定(bind)的属性符号

c# - 配置多个数据库 Entity Framework 6

.net - 如何不为种子实体设置 DatabaseGenerateOption.Identity

c# - 字符串表 : to add an int key, 或不添加?