由于IEnumerable.Contains()
方法不接受谓词作为参数,因此大多数人使用以下代码来检查是否存在与条件匹配的内容:
// ProductId is unique.
if (Products.Count(c => c.ProductId = 1234) == 1)
{
// Products list contains product 1234.
}
此代码强制遍历每个产品并检查它是否匹配。真的没有必要这样做。
在查看 Linq-to-SQL 生成的 SQL 代码时,也存在同样的问题。发送一个select count(*) ... where ProductId = @p0
语句,而不是if exists
.
如何通过 Linq 查找集合是否包含与条件匹配的项目,而不必遍历集合中的每个元素并计算匹配的数量?