linq动态多条件查询

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Linq.Expressions;

namespace ClassTest
{

    public static class PredicateExtensions
    {

        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>> expression1, Expression<Func<T, bool>> expression2)
        {

            var invokedExpression = Expression.Invoke(expression2, expression1.Parameters.Cast<Expression>());

            return Expression.Lambda<Func<T, bool>>(Expression.Or(expression1.Body, invokedExpression), expression1.Parameters);
        }

 

        public static Expression<Func<T, bool>> And<T>(this Expression<Func<T, bool>> expression1, Expression<Func<T, bool>> expression2)
        {

            var invokedExpression = Expression.Invoke(expression2, expression1.Parameters.Cast<Expression>());

            return Expression.Lambda<Func<T, bool>>(Expression.And(expression1.Body, invokedExpression), expression1.Parameters);

        }

    }
    public class Test
    {

        struct Product
        {
            public int productID;
            public string productName;
            public string productDesc;
        }
        static void Main()
        {
            List<Product> products = new List<Product>();
            Product product;
            product.productID = 1;
            product.productName = "aaa";
            product.productDesc = "good aaa";
            products.Add(product);
            product.productID = 1;
            product.productName = "bbb";
            product.productDesc = "good bbb";
            products.Add(product);
            product.productID = 3;
            product.productName = "ccc";
            product.productDesc = "good ccc";
            products.Add(product);
            product.productID = 4;
            product.productName = "ddd";
            product.productDesc = "good ddd";
            products.Add(product);

            var predicate = PredicateExtensions.True<Product>();
            int id=1;
            string name=null;
            string desc=null;

            if (id != 0)
                predicate=predicate.And(p => p.productID == id);
            if (!string.IsNullOrEmpty(name))
                predicate=predicate.And(p => p.productName.Contains(name));
            if (!string.IsNullOrEmpty(desc))
                predicate=predicate.And(p => p.productDesc.Contains(desc));

            var proList = products.AsQueryable().Where(predicate).Select(p=>p);

            foreach (var prod in proList)
                Console.WriteLine("{0} {1} {2}",prod.productID,prod.productName,prod.productDesc);
        }

 

    }
}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值