Linq 合並多個查詢條件


很多時候,我們的查詢條件有多個,並且參數不一樣,得到的查詢條件也就不一樣。這就要我們動態的生成查詢條件,再把這些查詢條件合並起來。網上找了這個類,可以很好的達到我們的要求。

public static class PredicateBuilder
    {
        public static Expression<Func<T, bool>> True<T>() { return f => true; }
        public static Expression<Func<T, bool>> False<T>() { return f => false; }

        public static Expression<Func<T, bool>> Or<T>(this Expression<Func<T, bool>> expr1,
                                                            Expression<Func<T, bool>> expr2)
        {
            var invokedExpr = Expression.Invoke(expr2, expr1.Parameters.Cast<Expression>());
            return Expression.Lambda<Func<T, bool>>
                  (Expression.Or(expr1.Body, invokedExpr), expr1.Parameters);
        }

        public static Expression<Func<T, bool>> And<T>(this Expression<Func<T, bool>> expr1,
                                                             Expression<Func<T, bool>> expr2)
        {
            var invokedExpr = Expression.Invoke(expr2, expr1.Parameters.Cast<Expression>());
            return Expression.Lambda<Func<T, bool>>
                  (Expression.And(expr1.Body, invokedExpr), expr1.Parameters);
        }
    }

 

測試一下:

 static void LinqAndTest()
        {
            List<string> list = new List<string>();
            list.Add("one");
            list.Add("two");
            list.Add("three");
            list.Add("four");
            list.Add("five");
            list.Add("six");

            //返回字長大於3
            Expression<Func<string, bool>> exp = s => s.Length > 3;
            var results= list.Where(exp.Compile());
            foreach (var result in results)
            {
                Console.WriteLine(result);
            }

            Expression<Func<string, bool>> exp2 = s => s.Contains('o');
            var exp3 = exp.And(exp2);
            //合並兩個條件:返回字長大於3且包括o字符
            results = list.Where(exp3.Compile());
            foreach (var result in results)
            {
                Console.WriteLine(result);
            }
            Console.Read();
            
        }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM