zoukankan      html  css  js  c++  java
  • C# 合并表达式树

    EF在存在多条件查询的时候,便存在合并表达式树的情况。

    实现代码:

                Expression<Func<Student, bool>> express1 = s => s.Name.Contains("奥特曼");
                Expression<Func<Student, bool>> express2 = s => s.Age>600000;
    
                //声明传递参数(也就是上面表达式树里面的参数s)
                ParameterExpression s = Expression.Parameter(typeof(Student), "s");
                //统一管理参数,保证参数一致,否则会报错 变量未定义
                MyExpressionVisitor visitor = new MyExpressionVisitor(s);
                //表达式树内容
                Expression body1 = visitor.Visit(express1.Body);
                Expression body2 = visitor.Visit(express2.Body);
                //合并表达式
                Expression<Func<Student, bool>> finalEx = Expression.Lambda<Func<Student, bool>>(Expression.AndAlso(body1, body2), s);
    
                //调用
                List<Student> list = stuList.Where(finalEx.Compile()).ToList();

    这里需要注意的是我使用了一个自定义类MyExpressionVisitor,他可以帮助我们管理表达式树传递的参数s。

    代码如下:

    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变量
            }
        }

    参考的博客:https://blog.csdn.net/xuchen_wang/article/details/91976111

    记录编程的点滴,体会学习的乐趣
  • 相关阅读:
    第八天-2019-12-3环境变量-自动挂载-别名
    Raid
    图文并茂 RAID 技术全解 – RAID0、RAID1、RAID5、RAID100
    第七天-2019-12-2改网卡,dns,挂载
    第六天2019-11-29vi命令使用技巧与架构目录
    linux目录架构
    第五天-2019-11-28基本配置命令
    第四天--2019-11-27网络信息配置
    ue4 Widget to RenderTarget
    UE4 ProcessEvent multiple parameters
  • 原文地址:https://www.cnblogs.com/AduBlog/p/14977677.html
Copyright © 2011-2022 走看看