c# - foreach 循环中的 DeleteObject()

标签 c# .net database entity-framework

使用 Entity Framework,我尝试像这样从我的对象上下文中删除一些对象:

foreach (var item in context.Items.Where( i => i.Value > 50 ) )
{
   context.Items.DeleteObject(item);
}

使用这段代码,我有一个“集合被修改”的异常。

那么,如何进行批量删除呢?

最佳答案

您必须首先从要修改的集合中获取要删除的项目。您可以使用简单的 LINQ 查询(使用 ToList() 强制执行)来执行此操作:

var toDelete = context.Items.Where(i => i.Value > 50).ToList();

foreach(var item in toDelete)
{
    context.Items.DeleteObject(item);
}

或者如果你喜欢简洁的语法(在这种情况下我不喜欢),你可以使用:

context.Items
    .Where(i => i.Value > 50)
    .ToList()
    .ForEach(item => context.Items.DeleteObject(item));

关于c# - foreach 循环中的 DeleteObject(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3204568/

相关文章:

c# - UWP 单元测试无法在 Visual Studio 2015 中初始化客户端代理

c# - Signalr:当用户为特定用户发送消息时无法发回消息

c# - 生成一个范围内的 N 个随机且唯一的数字

c# - 等同于 C# 中的协议(protocol)和委托(delegate)

php - 在多个数据库中插入数据

c# - Java 是编写音乐 DAW(数字音频工作站)的现实选择吗

c# - 如何在使用 sqlbulkcopy 之前创建表

c# - 如何在 WPF 中处理长时间运行的 "thread"?

database - 如何决定是否需要从 sqlite 过渡

database - 如何检查隔离级别?