我参加聚会迟到了,但是...
我最近创建了一个关于创建启用以下语法的 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);
这将创建您所追求的 or 查询。
希望这个答案仍然与您相关。