C# LINQ和OR标准
如何以编程方式创建EF查询(使用lambda的扩展方法)。我理解和标准。以下是伪代码:C# LINQ和OR标准,c#,.net,linq,entity-framework,predicatebuilder,C#,.net,Linq,Entity Framework,Predicatebuilder,如何以编程方式创建EF查询(使用lambda的扩展方法)。我理解和标准。以下是伪代码: var query = repository.Where(x => x.Name == "aName"); foreach(string filter in filters) { query = query.Where(x => x.FilterValue.Contains(filter)) } 但我要的不是and运算符。我想要一个电话或接线员。我该怎么做?如何在代码中创建复杂的条件树?
var query = repository.Where(x => x.Name == "aName");
foreach(string filter in filters)
{
query = query.Where(x => x.FilterValue.Contains(filter))
}
但我要的不是and运算符。我想要一个电话或接线员。我该怎么做?如何在代码中创建复杂的条件树?
PRindicateBuilder是一个很好的解决方案。但它很复杂,也不容易理解。请参阅评论中其他问题的链接
还发现这很有用:有时从另一个方向来比较方便:
string[] filter = {"A", "B"};
var returnValue = repository
.Where(x => x.Name == "aName")
.Where(x => filter.Any(f => (x.FilterValue).Contains(f)))
.ToList();
可能是重复的感谢史蒂文。这回答了我的问题。