Linq扩展方法

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

namespace Jusoft.ThirdParty.Extensions
{
    internal class ParameterReplacer : ExpressionVisitor
    {
        public ParameterReplacer(ParameterExpression paramExpr)
        {
            this.ParameterExpression = paramExpr;
        }

        public ParameterExpression ParameterExpression { get; private set; }

        public Expression Replace(Expression expr)
        {
            return this.Visit(expr);
        }

        protected override Expression VisitParameter(ParameterExpression p)
        {
            return this.ParameterExpression;
        }
    }
    /// <summary>
    /// Linq方法重写
    /// </summary>
    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>> And<T>(this Expression<Func<T, bool>> exp_left, Expression<Func<T, bool>> exp_right)
        {
            var candidateExpr = Expression.Parameter(typeof(T), "candidate");
            var parameterReplacer = new ParameterReplacer(candidateExpr);

            var left = parameterReplacer.Replace(exp_left.Body);
            var right = parameterReplacer.Replace(exp_right.Body);
            var body = Expression.And(left, right);

            return Expression.Lambda<Func<T, bool>>(body, candidateExpr);
        }

        public static Expression<Func<T, bool>> Or<T>(this Expression<Func<T, bool>> exp_left, Expression<Func<T, bool>> exp_right)
        {
            var candidateExpr = Expression.Parameter(typeof(T), "candidate");
            var parameterReplacer = new ParameterReplacer(candidateExpr);

            var left = parameterReplacer.Replace(exp_left.Body);
            var right = parameterReplacer.Replace(exp_right.Body);
            var body = Expression.Or(left, right);

            return Expression.Lambda<Func<T, bool>>(body, candidateExpr);
        }
    }
}

使用方法

 Expression<Func<Customer, bool>> where = PredicateExtensions.True<CustomerList>();
            if (condition.StartTime.HasValue)//时间
            {
                where = where.And(p => p.CreateTime > condition.StartTime && p.CreateTime <= condition.EndTime);
            }
            if (condition.CustomerType.HasValue)
            {
                where = where.And(p => p.StateId == condition.CustomerType);
            }
            var data = dbContext.CustomerList.Where(where);

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
LINQ(Language Integrated Query)是.NET Framework的一种语言集成查询,它允许我们在C#或VB.NET代码中使用SQL类似的语法来查询数据。LINQ扩展方法是一种在LINQ查询中使用的方法,它们可以用于对数据进行排序、筛选、分组和投影等操作,以及执行聚合函数。 下面是几个LINQ扩展方法的应用实例: 1. Where方法:筛选符合条件的元素 ```csharp List<int> numbers = new List<int> { 1, 2, 3, 4, 5, 6 }; IEnumerable<int> result = numbers.Where(n => n % 2 == 0); ``` 2. OrderBy方法:按照指定的方式排序 ```csharp List<int> numbers = new List<int> { 6, 2, 4, 1, 5, 3 }; IEnumerable<int> result = numbers.OrderBy(n => n); ``` 3. GroupBy方法:按照指定的字段进行分组 ```csharp List<Person> people = new List<Person> { new Person { Name = "Alice", Age = 25 }, new Person { Name = "Bob", Age = 30 }, new Person { Name = "Charlie", Age = 25 }, new Person { Name = "Dave", Age = 30 } }; IEnumerable<IGrouping<int, Person>> result = people.GroupBy(p => p.Age); ``` 4. Select方法:对查询结果进行投影 ```csharp List<Person> people = new List<Person> { new Person { Name = "Alice", Age = 25 }, new Person { Name = "Bob", Age = 30 }, new Person { Name = "Charlie", Age = 25 }, new Person { Name = "Dave", Age = 30 } }; IEnumerable<string> result = people.Select(p => p.Name); ``` 这些方法只是LINQ扩展方法中的一部分,它们的应用可以大大简化我们对数据的处理。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值