zoukankan      html  css  js  c++  java
  • ExpressionHelp2

    public static class ExpressionHelp
    {
    private static Expression<T> Combine<T>(this Expression<T> first, Expression<T> second, Func<Expression, Expression, Expression> merge)
    {
    MyExpressionVisitor visitor = new MyExpressionVisitor(first.Parameters[0]);
    Expression bodyone = visitor.Visit(first.Body);
    Expression bodytwo = visitor.Visit(second.Body);
    return Expression.Lambda<T>(merge(bodyone, bodytwo), first.Parameters[0]);
    }
    /// <summary>
    /// 条件合并,以and 的逻辑合并两个表达式
    /// </summary>
    /// <typeparam name="T"></typeparam>
    /// <param name="first"></param>
    /// <param name="second"></param>
    /// <returns></returns>
    public static Expression<Func<T, bool>> ExpressionAnd<T>(this Expression<Func<T, bool>> first, Expression<Func<T, bool>> second)
    {
    return first.Combine(second, Expression.And);
    }
    /// <summary>
    /// 条件合并,以or 的逻辑合并两个表达式
    /// </summary>
    /// <typeparam name="T"></typeparam>
    /// <param name="first"></param>
    /// <param name="second"></param>
    /// <returns></returns>
    public static Expression<Func<T, bool>> ExpressionOr<T>(this Expression<Func<T, bool>> first, Expression<Func<T, bool>> second)
    {
    return first.Combine(second, Expression.Or);
    }

    /// <summary>
    /// 查询语句,查询字段在 keywords中, 值为T 实体中与其对应的关键字包含值的数据。
    /// </summary>
    /// <typeparam name="T">实体类型 </typeparam>
    /// <param name="item">实体</param>
    /// <param name="Keywords">判断关键字</param>
    /// <returns></returns>
    public static Expression<Func<T, bool>> EntityEquel_Expression<T>(T item, List<string> Keywords)
    {
    Type entityType = typeof(T);
    Expression<Func<T, bool>> expression = null;
    ParameterExpression paramExpr = Expression.Parameter(typeof(T), "e");
    foreach (var keyWord in Keywords)
    {
    Expression<Func<T, bool>> lambda;
    string field = keyWord;//关键字
    PropertyInfo proInfo = entityType.GetProperty(field);
    var keyValue = proInfo.GetValue(item);
    MemberExpression mExpr = Expression.Property(paramExpr, field);  
    ConstantExpression cExpr = Expression.Constant(keyValue, proInfo.PropertyType);  
    BinaryExpression bExpr = Expression.Equal(mExpr, cExpr);   
    Expression whereExpr = bExpr;
    lambda = Expression.Lambda<Func<T, bool>>(whereExpr, paramExpr);
    if (expression != null)
    {
    expression = expression.ExpressionAnd(lambda);
    }
    else
    {
    expression = lambda;
    }
    }
    return expression;
    }
    /// <summary>
    /// 包含查询关键字 是否包含在list中 相当于sql中的 select key in (设定的值)
    /// </summary>
    /// <typeparam name="T">实体类</typeparam>
    /// <param name="KeyValues"> 数据判断 字段 ,string 为 实体内的某个字符,list<string> 为包含该字符的条件 </param>
    /// <returns></returns>
    public static Expression<Func<T, bool>> In_Expression<T>(Dictionary<string, List<string>> KeyValues)
    {
    Type entityType = typeof(T);
    Expression<Func<T, bool>> expression = null;
    ParameterExpression paramExpr = Expression.Parameter(typeof(T), "e");
    foreach (var keyItem in KeyValues)
    {
    foreach (var keyValue in KeyValues[keyItem.Key])
    {
    Expression<Func<T, bool>> lambda;
    string field = keyItem.Key;//关键字
    PropertyInfo proInfo = entityType.GetProperty(field);
    MemberExpression mExpr = Expression.Property(paramExpr, field);  
    ConstantExpression cExpr = Expression.Constant(keyValue, proInfo.PropertyType);  
    BinaryExpression bExpr = Expression.Equal(mExpr, cExpr);   
    Expression whereExpr = bExpr;
    lambda = Expression.Lambda<Func<T, bool>>(whereExpr, paramExpr);
    if (expression != null)
    {
    expression = expression.ExpressionOr(lambda);
    }
    else
    {
    expression = lambda;
    }
    }
    }
    return expression;
    }

    /// <summary>
    /// 等于
    /// </summary>
    /// <typeparam name="T">实体类</typeparam>
    /// <param name="key">关键字</param>
    /// <param name="keyItem">关键字对应的值</param>
    /// <returns></returns>
    public static Expression<Func<T, bool>> Equel_Expression<T>(string key, object keyItem)
    {

    Type entityType = typeof(T);
    ParameterExpression paramExpr = Expression.Parameter(typeof(T), "e");
    Expression<Func<T, bool>> lambda;
    lambda = Equel128_GetExpression<T>(key, keyItem, true);
    if (lambda != null)
    {
    return lambda;
    }
    string field = key;//关键字
    PropertyInfo proInfo = entityType.GetProperty(field);
    var keyValue = keyItem;
    MemberExpression mExpr = Expression.Property(paramExpr, field);  
    ConstantExpression cExpr = Expression.Constant(keyValue, proInfo.PropertyType);  

    BinaryExpression bExpr = Expression.Equal(mExpr, cExpr);   

    Expression whereExpr = bExpr;
    lambda = Expression.Lambda<Func<T, bool>>(whereExpr, paramExpr);
    return lambda;
    }

    /// <summary>
    /// 大于
    /// </summary>
    /// <typeparam name="T">实体类</typeparam>
    /// <param name="key">关键字</param>
    /// <param name="keyItem">关键字对应的值</param>
    /// <returns></returns>
    public static Expression<Func<T, bool>> Greaterthan_Expression<T>(string key, object keyItem)
    {
    Type entityType = typeof(T);
    ParameterExpression paramExpr = Expression.Parameter(typeof(T), "e");
    Expression<Func<T, bool>> lambda;
    string field = key;//关键字
    PropertyInfo proInfo = entityType.GetProperty(field);
    var keyValue = keyItem;
    MemberExpression mExpr = Expression.Property(paramExpr, field);  
    ConstantExpression cExpr = Expression.Constant(keyValue, proInfo.PropertyType);  
    BinaryExpression bExpr = Expression.GreaterThan(mExpr, cExpr);   
    Expression whereExpr = bExpr;
    lambda = Expression.Lambda<Func<T, bool>>(whereExpr, paramExpr);

    return lambda;
    }
    /// <summary>
    /// 大于等于
    /// </summary>
    /// <typeparam name="T">实体类</typeparam>
    /// <param name="key">关键字</param>
    /// <param name="keyItem">关键字对应的值</param>
    /// <returns></returns>
    public static Expression<Func<T, bool>> GreaterThanOrEqual_Expression<T>(string key, object keyItem)
    {
    Type entityType = typeof(T);
    ParameterExpression paramExpr = Expression.Parameter(typeof(T), "e");
    Expression<Func<T, bool>> lambda;
    string field = key;//关键字
    PropertyInfo proInfo = entityType.GetProperty(field);
    var keyValue = keyItem;
    MemberExpression mExpr = Expression.Property(paramExpr, field);  
    ConstantExpression cExpr = Expression.Constant(keyValue, proInfo.PropertyType);  
    BinaryExpression bExpr = Expression.GreaterThanOrEqual(mExpr, cExpr);   
    Expression whereExpr = bExpr;
    lambda = Expression.Lambda<Func<T, bool>>(whereExpr, paramExpr);

    return lambda;
    }

    /// <summary>
    /// 小于
    /// </summary>
    /// <typeparam name="T">实体类</typeparam>
    /// <param name="key">关键字</param>
    /// <param name="keyItem">关键字对应的值</param>
    /// <returns></returns>
    public static Expression<Func<T, bool>> LessThan_Expression<T>(string key, object keyItem)
    {
    Type entityType = typeof(T);
    ParameterExpression paramExpr = Expression.Parameter(typeof(T), "e");
    Expression<Func<T, bool>> lambda;
    string field = key;//关键字
    PropertyInfo proInfo = entityType.GetProperty(field);
    var keyValue = keyItem;
    MemberExpression mExpr = Expression.Property(paramExpr, field);  
    ConstantExpression cExpr = Expression.Constant(keyValue, proInfo.PropertyType);  
    BinaryExpression bExpr = Expression.LessThan(mExpr, cExpr);   
    Expression whereExpr = bExpr;
    lambda = Expression.Lambda<Func<T, bool>>(whereExpr, paramExpr);
    return lambda;
    }

    /// <summary>
    /// 小于等于
    /// </summary>
    /// <typeparam name="T">实体类</typeparam>
    /// <param name="key">关键字</param>
    /// <param name="keyItem">关键字对应的值</param>
    /// <returns></returns>
    public static Expression<Func<T, bool>> LessThanOrEqual_Expression<T>(string key, object keyItem)
    {
    Type entityType = typeof(T);
    ParameterExpression paramExpr = Expression.Parameter(typeof(T), "e");
    Expression<Func<T, bool>> lambda;
    string field = key;//关键字
    PropertyInfo proInfo = entityType.GetProperty(field);
    var keyValue = keyItem;
    MemberExpression mExpr = Expression.Property(paramExpr, field);  
    ConstantExpression cExpr = Expression.Constant(keyValue, proInfo.PropertyType);  
    BinaryExpression bExpr = Expression.LessThanOrEqual(mExpr, cExpr);   
    Expression whereExpr = bExpr;
    lambda = Expression.Lambda<Func<T, bool>>(whereExpr, paramExpr);
    return lambda;
    }

    /// <summary>
    /// 不等于
    /// </summary>
    /// <typeparam name="T">实体类</typeparam>
    /// <param name="key">关键字</param>
    /// <param name="keyItem">关键字对应的值</param>
    /// <returns></returns>
    public static Expression<Func<T, bool>> NotEqual_Expression<T>(string key, object keyItem)
    {
    Type entityType = typeof(T);
    ParameterExpression paramExpr = Expression.Parameter(typeof(T), "e");
    Expression<Func<T, bool>> lambda;
    lambda = Equel128_GetExpression<T>(key, keyItem, false);
    if (lambda != null)
    {
    return lambda;
    }
    string field = key;//关键字
    PropertyInfo proInfo = entityType.GetProperty(field);
    var keyValue = keyItem;
    MemberExpression mExpr = Expression.Property(paramExpr, field);  
    ConstantExpression cExpr = Expression.Constant(keyValue, proInfo.PropertyType);  
    BinaryExpression bExpr = Expression.NotEqual(mExpr, cExpr);   
    Expression whereExpr = bExpr;
    lambda = Expression.Lambda<Func<T, bool>>(whereExpr, paramExpr);
    return lambda;
    }

    #region 自定义字段
    /// <summary>
    ///判断 decimal128 格式并进行处理
    /// </summary>
    /// <typeparam name="T">实体</typeparam>
    /// <param name="name">关键字</param>
    /// <param name="keyItem">值</param>
    /// <param name="isEquel">是否相等 true等于 false 不等于</param>
    /// <returns></returns>
    private static Expression<Func<T, bool>> Equel128_GetExpression<T>(string name, object keyItem, bool isEquel)
    {
    Expression<Func<T, bool>> lambda = null;
    Type entityType = typeof(T);
    var param = Expression.Parameter(typeof(T), "x");
    PropertyInfo proInfo = entityType.GetProperty(name);
    var type = proInfo.PropertyType.FullName;
    try
    {
    if (type.Contains("System.Decimal") && type != "System.Decimal")//包含但是不等于相当于 为decimal? 格式。否则相当于decimal格式
    {
    Decimal128 kk = Decimal128.Parse(keyItem.ToString());
    BsonDecimal128 aa = new BsonDecimal128(kk);
    ParameterExpression parameter = Expression.Parameter(typeof(T), "p");
    MemberExpression member = Expression.PropertyOrField(parameter, name);
    var addMethod = typeof(decimal?).GetMethod("Equals");
    ConstantExpression constant = Expression.Constant(aa, typeof(BsonDecimal128));
    if (isEquel)
    {
    lambda = Expression.Lambda<Func<T, bool>>(Expression.Call(member, addMethod, constant), parameter);
    }
    else
    {
    lambda = Expression.Lambda<Func<T, bool>>(Expression.Not(Expression.Call(member, addMethod, constant)), parameter);
    }
    }
    }
    catch (Exception ex)
    {
    lambda = null;
    }
    return lambda;
    }
    #endregion

    }
    public class MyExpressionVisitor : ExpressionVisitor
    {
    public ParameterExpression _Parameter { get; set; }

    public MyExpressionVisitor(ParameterExpression Parameter)
    {
    _Parameter = Parameter;
    }
    protected override Expression VisitParameter(ParameterExpression p)
    {
    return _Parameter;
    }

    public override Expression Visit(Expression node)
    {
    return base.Visit(node);//Visit会根据VisitParameter()方法返回的Expression修改这里的node变量
    }
    }

  • 相关阅读:
    并发基础(一) 线程介绍
    java基础(九) 可变参数列表介绍
    全球 43 亿 IPv4 地址已耗尽!IPv6,刻不容缓
    IPv6,无需操作就可升级?
    为什么 HTTPS 比 HTTP 安全
    从《国产凌凌漆》看到《头号玩家》,你就能全面了解5G
    再谈 APISIX 高性能实践
    API 网关的选型和持续集成
    尹吉峰:使用 OpenResty 搭建高性能 Web 应用
    鱼和熊掌可兼得?一文看懂又拍云 SCDN
  • 原文地址:https://www.cnblogs.com/lvlaozf/p/12875012.html
Copyright © 2011-2022 走看看