带有Or的IQueryable Where扩展方法
作者:互联网
这个问题已经在这里有了答案: > How to dynamically add OR operator to WHERE clause in LINQ 4个
重复:
07001
我想遍历字符串值数组并构建一个linq表达式
列表中的每个项目都经过“或”运算的地方.
string[] search = new string[]{"A", "B", "C"};
foreach (string item in filterValues)
{
searchQuery = searchQuery.Where(s => s.Name.Contains(item));
}
上面的代码搜索“ A”,“ B”和“ C”
我要搜索“ A”或“ B”或“ C”.
我知道如何使用Linq做到这一点,但我想使用扩展方法来完成同样的事情.
解决方法:
我晚会晚了,但是…
我最近创建了一个博客,内容涉及创建支持以下语法的IQueryable搜索扩展方法:
string[] search = new string[]{"A", "B", "C"};
var searchQuery = context.Users.Search(u => u.Name, search);
更新:START
此后,我已经更新了搜索扩展,这些扩展影响了使用新的流畅API进行搜索的方式.这意味着以上内容不应写为
var searchQuery = context.Users.Search(u => u.Name)
.Containing("A", "B", "C");
有关新API的更多信息,请参见此处:http://jnye.co/Posts/2030/searchextensions-search-strings-with-the-new-fluent-api
更新:END
http://jnye.co/Posts/8/generic-iqueryable-or-search-for-multiple-search-terms-using-expression-trees
https://github.com/ninjanye/SearchExtensions
我还有一个nuget软件包,您可以从这里安装:
http://www.nuget.org/packages/NinjaNye.SearchExtensions/
但是,如果您想自己执行此操作,则需要执行以下操作:
首先,您需要创建扩展方法
public static class QueryableExtensions
{
public static IQueryable<T> Search<T>(this IQueryable<T> source, Expression<Func<T, string>> stringProperty, params string[] searchTerms)
{
if (!searchTerms.Any())
{
return source;
}
Expression orExpression = null;
foreach (var searchTerm in searchTerms)
{
//Create expression to represent x.[property].Contains(searchTerm)
var searchTermExpression = Expression.Constant(searchTerm);
var containsExpression = BuildContainsExpression(stringProperty, searchTermExpression);
orExpression = BuildOrExpression(orExpression, containsExpression);
}
var completeExpression = Expression.Lambda<Func<T, bool>>(orExpression, stringProperty.Parameters);
return source.Where(completeExpression);
}
private static Expression BuildOrExpression(Expression existingExpression, Expression expressionToAdd)
{
if (existingExpression == null)
{
return expressionToAdd;
}
//Build 'OR' expression for each property
return Expression.OrElse(existingExpression, expressionToAdd);
}
}
然后可以按以下方式使用它:
string[] search = new string[]{"A", "B", "C"};
var searchQuery = context.Users.Search(u => u.Name, search);
这将创建您所追求的或查询.
希望这个答案对您仍然有用.
标签:iqueryable,linq,c 来源: https://codeday.me/bug/20191024/1921082.html