zoukankan      html  css  js  c++  java
  • linq多个条件

    public static class PredicateBuilder
    {
    /// <summary>
    /// 机关函数应用True时:单个AND有效,多个AND有效;单个OR无效,多个OR无效;混应时写在AND后的OR有效。
    /// 即,设置为True时所有or语句应该放在and语句之后,否则无效
    /// </summary>
    public static Expression<Func<T, bool>> True<T>() { return f => true; }
    /// <summary>
    /// 机关函数应用False时:单个AND无效,多个AND无效;单个OR有效,多个OR有效;混应时写在OR后面的AND有效。
    /// 即,设置为False时所有or语句应该放在and语句之前,否则无效
    /// </summary>
    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);
    }
    }

    使用

    var predicate = PredicateBuilder.False<op_client_main_caccount>();
    foreach (var id in errorId)
    {
    predicate = predicate.Or(p => p.id == id);
    }
    List<op_client_main_caccount> errorData = new List<op_client_main_caccount>();
    errorData = mainDatas.Where(predicate.Compile()).ToList();

    /// <summary>
        /// Enables the efficient, dynamic composition of query predicates.
        /// </summary>
        public static class LinqExtensions
        {
            public static Expression Property(this Expression expression, string propertyName)
            {
                return Expression.Property(expression, propertyName);
            }
            public static Expression AndAlso(this Expression left, Expression right)
            {
                return Expression.AndAlso(left, right);
            }
            public static Expression Call(this Expression instance, string methodName, params Expression[] arguments)
            {
                return Expression.Call(instance, instance.Type.GetMethod(methodName), arguments);
            }
            public static Expression GreaterThan(this Expression left, Expression right)
            {
                return Expression.GreaterThan(left, right);
            }
            public static Expression<T> ToLambda<T>(this Expression body, params  ParameterExpression[] parameters)
            {
                return Expression.Lambda<T>(body, parameters);
            }
            public static Expression<Func<T, bool>> True<T>() { return param => true; }
            public static Expression<Func<T, bool>> False<T>() { return param => false; }
            /// <summary>
            /// 组合And
            /// </summary>
            /// <returns></returns>
            public static Expression<Func<T, bool>> And<T>(this Expression<Func<T, bool>> first, Expression<Func<T, bool>> second)
            {
                return first.Compose(second, Expression.AndAlso);
            }
            /// <summary>
            /// 组合Or
            /// </summary>
            /// <returns></returns>
            public static Expression<Func<T, bool>> Or<T>(this Expression<Func<T, bool>> first, Expression<Func<T, bool>> second)
            {
                return first.Compose(second, Expression.OrElse);
            }
    
            /// <summary>
            /// Combines the first expression with the second using the specified merge function.
            /// </summary>
            static Expression<T> Compose<T>(this Expression<T> first, Expression<T> second, Func<Expression, Expression, Expression> merge)
            {
                var map = first.Parameters
                    .Select((f, i) => new { f, s = second.Parameters[i] })
                    .ToDictionary(p => p.s, p => p.f);
                var secondBody = ParameterRebinder.ReplaceParameters(map, second.Body);
                return Expression.Lambda<T>(merge(first.Body, secondBody), first.Parameters);
            }
    
            /// <summary>
            /// ParameterRebinder
            /// </summary>
            private class ParameterRebinder : ExpressionVisitor
            {
                /// <summary>
                /// The ParameterExpression map
                /// </summary>
                readonly Dictionary<ParameterExpression, ParameterExpression> map;
                /// <summary>
                /// Initializes a new instance of the <see cref="ParameterRebinder"/> class.
                /// </summary>
                /// <param name="map">The map.</param>
                ParameterRebinder(Dictionary<ParameterExpression, ParameterExpression> map)
                {
                    this.map = map ?? new Dictionary<ParameterExpression, ParameterExpression>();
                }
                /// <summary>
                /// Replaces the parameters.
                /// </summary>
                /// <param name="map">The map.</param>
                /// <param name="exp">The exp.</param>
                /// <returns>Expression</returns>
                public static Expression ReplaceParameters(Dictionary<ParameterExpression, ParameterExpression> map, Expression exp)
                {
                    return new ParameterRebinder(map).Visit(exp);
                }
                /// <summary>
                /// Visits the parameter.
                /// </summary>
                /// <param name="p">The p.</param>
                /// <returns>Expression</returns>
                protected override Expression VisitParameter(ParameterExpression p)
                {
                    ParameterExpression replacement;
    
                    if (map.TryGetValue(p, out replacement))
                    {
                        p = replacement;
                    }
                    return base.VisitParameter(p);
                }
            }
        }
  • 相关阅读:
    C#根据长度创建数组
    PLC读取数据高低位交换,批量保存到list集合,方便调用。
    C#读取图片流保存到文件,再读取流文件,把图片再显示出来
    C#从SQL server数据库中读取l图片和存入图片[转]
    C# 数据库查询表字段,写入到combox
    C# MSSQL数据库查询SQL语句拼接
    C# winform只允许程序运行一个
    C# 定时关机代码
    C#用委托来动态显示日期和时间
    使用margin负值实现压住相邻边距
  • 原文地址:https://www.cnblogs.com/shuaimeng/p/9717042.html
Copyright © 2011-2022 走看看