其他分享
首页 > 其他分享> > 带有Or的IQueryable Where扩展方法

带有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