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

    记录编程的点滴,体会学习的乐趣
  • 相关阅读:
    fiddler 抓包工具(新猿旺学习总结)
    Monkey之常用ADB命令(新猿旺学习总结)
    APP压力测试 monkey(新猿旺学习总结)
    linux 系统shell运行程序不退出
    c++字节对齐编译器指令#pragma
    vmware 14 新安装centos7 没法联网
    windows dll的def文件
    c编译器字节对齐指令
    centos 7 进入图形界面
    cent os 7 与cent os 6区别
  • 原文地址:https://www.cnblogs.com/AduBlog/p/14977677.html
Copyright © 2011-2022 走看看