Ну, у меня есть одна-ко-многим связанная модель:
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);
с дополнительным свойством Parent_Id в классе Child
public class Child
{
...
public int Parent_Id { get; set; }
...
}
Итак, как я могу правильно настроить каскадное удаление? Или как я должен удалить эти дочерние объекты? Я предполагаю, что это случайная задача, но я просто что-то пропустил.