C#动态查询:巧用Expression组合多条件表达式

简介: 在C#中,利用`Expression`类和`AndAlso`、`OrElse`方法,可以组合两个`Expression<Func<T, bool>>`以实现动态多条件查询。该方法通过构建表达式树,方便地构建复杂查询。示例代码展示了如何创建表达式树,分别检查年龄大于等于18和姓名为"John"的条件,并使用`AndAlso`组合这两个条件,最终编译为可执行的委托进行测试。

概述:在C#中,通过`Expression`类、`AndAlso`和`OrElse`方法可组合两个`Expression<Func<T, bool>>`,实现多条件动态查询。通过创建表达式树,可轻松构建复杂的查询条件。

在C#中,可以使用AndAlsoOrElse方法组合两个Expression<Func<T, bool>>类型的表达式。以下是详细解释和实例源代码:

方法和步骤:

  1. 使用Expression类创建表达式树。
  2. 使用AndAlsoOrElse方法组合两个表达式。

详细实例源代码:

using System;
using System.Linq.Expressions;
class Program
{
    static void Main()
    {
        // 步骤1:定义Person类
        class Person
        {
            public string Name { get; set; }
            public int Age { get; set; }
        }
        // 步骤2:创建Expression参数
        ParameterExpression parameter = Expression.Parameter(typeof(Person), "p");
        // 步骤3:创建第一个表达式,检查年龄是否大于等于 18
        Expression<Func<Person, bool>> ageExpression = Expression.Lambda<Func<Person, bool>>(
            Expression.GreaterThanOrEqual(
                Expression.Property(parameter, nameof(Person.Age)),
                Expression.Constant(18)
            ),
            parameter
        );
        // 步骤4:创建第二个表达式,检查姓名是否为 "John"
        Expression<Func<Person, bool>> nameExpression = Expression.Lambda<Func<Person, bool>>(
            Expression.Equal(
                Expression.Property(parameter, nameof(Person.Name)),
                Expression.Constant("John")
            ),
            parameter
        );
        // 步骤5:组合表达式,要求年龄大于等于 18 且姓名为 "John"
        Expression<Func<Person, bool>> combinedExpression = Expression.Lambda<Func<Person, bool>>(
            Expression.AndAlso(ageExpression.Body, nameExpression.Body),
            parameter
        );
        // 步骤6:编译并使用组合后的表达式
        var compiledExpression = combinedExpression.Compile();
        // 步骤7:创建Person对象并测试
        var person1 = new Person { Name = "John", Age = 20 };
        var person2 = new Person { Name = "Alice", Age = 25 };
        Console.WriteLine(compiledExpression(person1)); // 输出 True
        Console.WriteLine(compiledExpression(person2)); // 输出 False
    }
}

在这个例子中,AndAlso方法用于将两个表达式组合成一个逻辑与的表达式。创建了两个简单的表达式来检查年龄和姓名条件,然后通过AndAlso方法组合成一个新的表达式。最后,使用Compile方法将组合后的表达式编译为委托,可以用于实际的数据测试。

相关文章
|
6月前
|
开发框架 .NET 编译器
C# 10.0中Lambda表达式的改进:更简洁、更灵活的代码编写体验
【1月更文挑战第21天】随着C#语言的不断发展,Lambda表达式作为一种简洁、高效的函数式编程工具,在C# 10.0中迎来了重要的改进。本文将详细探讨C# 10.0中Lambda表达式的新特性,包括参数类型的推断增强、自然类型的Lambda参数以及Lambda表达式的属性改进等。这些改进不仅简化了Lambda表达式的编写过程,还提升了代码的可读性和灵活性,为开发者带来了更优质的编程体验。
|
开发框架 .NET C#
ASP.Net c# 正则表达式 子表达式 group
ASP.Net c# 正则表达式 子表达式 group
64 0
|
2月前
|
开发框架 自然语言处理 .NET
C#一分钟浅谈:LINQ 查询表达式的使用技巧
【9月更文挑战第6天】LINQ(Language Integrated Query)是C#开发中的强大工具,使查询数据集合变得简单且接近自然语言。本文从基础入手,通过具体示例讲解LINQ查询表达式的使用技巧,包括过滤、排序和分组等操作。同时,文章还探讨了常见问题及解决方法,如性能优化、过早枚举和类型转换等,帮助开发者写出更高效、易维护的代码。
94 15
|
2月前
|
C#
C#一分钟浅谈:Lambda 表达式和匿名方法
本文详细介绍了C#编程中的Lambda表达式与匿名方法,两者均可用于定义无名函数,使代码更简洁易维护。文章通过基础概念讲解和示例对比,展示了各自语法特点,如Lambda表达式的`(parameters) =&gt; expression`形式及匿名方法的`delegate(parameters)`结构。并通过实例演示了两者的应用差异,强调了在使用Lambda时应注意闭包问题及其解决策略,推荐优先使用Lambda表达式以增强代码可读性。
41 8
|
4月前
|
SQL 开发框架 前端开发
在C#开发中使用第三方组件LambdaParser、DynamicExpresso、Z.Expressions,实现动态解析/求值字符串表达式
在C#开发中使用第三方组件LambdaParser、DynamicExpresso、Z.Expressions,实现动态解析/求值字符串表达式
|
6月前
|
SQL 开发框架 .NET
C#linq表达式的应用
C#linq表达式的应用
39 0
|
Java 编译器 C#
C#中的Lambda表达式
C#中的Lambda表达式
70 0
|
6月前
|
开发框架 .NET 编译器
C#学习相关系列之匿名方法和Lambda表达式
C#学习相关系列之匿名方法和Lambda表达式
|
6月前
|
开发框架 .NET 编译器
C# 9.0中的目标类型新表达式:类型推断的又一进步
【1月更文挑战第16天】C# 9.0引入了目标类型新表达式,这是类型推断功能的一个重要扩展。通过目标类型新表达式,开发者在创建对象时可以省略类型名称,编译器会根据上下文自动推断所需类型。这一特性不仅简化了代码编写,还提高了代码的可读性和维护性。本文将详细介绍目标类型新表达式的语法、使用场景及其对C#编程的影响。
|
6月前
|
机器学习/深度学习 开发框架 .NET
C# 中的 Lambda 表达式:一种简洁而强大的编程工具
【1月更文挑战第6天】在现代编程中,Lambda 表达式已经成为一种非常流行的编程范式。C# 作为一种功能强大的、面向对象的编程语言,自然也不例外。Lambda 表达式在 C# 中提供了一种简洁、灵活的方式来表示匿名函数。这些函数可以被用作委托或表达式树类型,从而在各种不同的上下文中使用。