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

posted @   RookieCoderAdu  阅读(395)  评论(1编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示