我迟到了,但是……
我最近创建了一个关于创建启用以下语法的 IQueryable 搜索扩展方法的博客:
string[] search = new string[]{"A", "B", "C"};
var searchQuery = context.Users.Search(u => u.Name, search);
更新:开始
我已经更新了搜索扩展,这影响了搜索的执行方式以使用新的流畅 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
更新:结束
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);
这将创建您所追求的或查询。
希望这个答案仍然与您相关。