c# - List<T> RemoveAll() 没有删除项目

标签 c# linq list

我有一个看起来像这样的对象:

{
  "Text" : "Another lovely alert",
  "Category" : 2,
  "UserAlerts" : [{ "UserId" : 2 }]
}

这将传递给 Web API 并正确绑定(bind)到:

[Key, Column(Order = 0)]
public long UserId { get; set; }

[Key, Column(Order = 1)]
public Guid AlertId { get; set; }

public virtual User User { get; set; }

public virtual Alert Alert { get; set; }

然后我运行以下命令,期望 ID 为 2 的 UserAlert 被删除,但对象没有改变。

alert.UserAlerts.ToList().RemoveAll(x => userIds.Contains(x.UserId));

alert.UserAlerts.ToList().RemoveAll(x => x.UserId == 2);

第二个查询更简单,但这也没有做任何事情。我不知道哪里出了问题。

最佳答案

这是因为通过使用 ToList,您正在创建新的 List 对象,然后从它而不是从原始 IEnumerable 中删除项目。

尝试使用这个:

alert.UserAlerts = alert.UserAlerts.Where(x => x.UserId != 2);

你不能在 IEnumerable 上运行 RemoveAll,所以我认为在这里使用 Linq 是个好主意。您将拥有不具有 UserId=2 的项目集合,这相当于删除所有具有 UserId=2 的项目。您需要从 RemoveAll 中反转您的查询,它在任何情况下都有效。

关于c# - List<T> RemoveAll() 没有删除项目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33211594/

相关文章:

python - 根据python中单词中的元音数量对列表进行排序

c# - 如何从 List<T> 获取 IEnumerable<T>?

使用 bool 表达式的 C# Entity Framework 查询?

c# - 创建动态类型集合和数组

c# - 在 linq 中使用 equals 关键字

linq - 帮助将 foreach 转换为 Linq

jquery 针对单个生成的列表标签

c# - 意外的元组不等式

c# - 如何在 .NET 中创建虚拟网络适配器?

c# - 为什么 EF 在进行一对多连接时会不必要地检索 ID?