当前位置: 欣欣网 > 码农

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

2024-05-14码农

在C#中,当我们需要根据用户输入或其他动态条件来构建复杂的查询时,使用 Expression 类可以非常灵活地构建和执行这些查询。 Expression 类位于 System.Linq.Expressions 命名空间中,它允许我们在运行时动态地构建表达式树,这些表达式树可以被编译成可执行的代码。

下面,我们将探讨如何使用 Expression 类来动态地组合多个查询条件。

一、了解Expression类

Expression 类是.NET Framework中用于表示表达式树的所有节点的基类。表达式树是一种数据结构,它表示了代码中的表达式。通过构建和修改这些树,我们可以在运行时动态地创建和修改代码。

二、构建基本表达式

首先,我们需要了解如何构建基本的表达式。以下是一个简单的例子,它创建了一个表示两个整数相加的表达式:

var left = Expression.Constant(5);
var right = Expression.Constant(3);
var sum = Expression.Add(left, right);
var lambda = Expression.Lambda<Func<int>>(sum);
var result = lambda.Compile()(); // 编译并执行表达式,结果为8

三、构建动态查询条件

现在,让我们来看一个更复杂的例子,我们将构建一个动态的多条件查询。假设我们有一个 Person 类,我们想要根据用户的输入来动态地构建查询条件。

public classPerson
{
publicstring Name { getset; }
publicint Age { getset; }
publicstring City { getset; }
}

假设用户提供了两个查询条件:年龄大于25岁,并且居住在城市"New York"。我们可以使用 Expression 类来动态地构建这个查询:

var param = Expression.Parameter(typeof(Person), "p");
var ageProperty = Expression.Property(param, "Age");
var ageConstant = Expression.Constant(25);
var ageComparison = Expression.GreaterThan(ageProperty, ageConstant);
var cityProperty = Expression.Property(param, "City");
var cityConstant = Expression.Constant("New York");
var cityComparison = Expression.Equal(cityProperty, cityConstant);
var combinedCondition = Expression.AndAlso(ageComparison, cityComparison);
var lambda = Expression.Lambda<Func<Person, bool>>(combinedCondition, param);
var predicate = lambda.Compile();

现在,我们可以使用这个编译后的谓词来查询一个 Person 列表:

var people = new List<Person>
{
new Person { Name = "Alice", Age = 30, City = "New York" },
new Person { Name = "Bob", Age = 20, City = "Los Angeles" },
new Person { Name = "Charlie", Age = 35, City = "New York" }
};
var filteredPeople = people.Where(predicate).ToList(); // 将只包含Alice和Charlie的记录

四、结论

通过使用 Expression 类,我们可以非常灵活地构建和执行动态查询。这对于根据用户输入或其他动态条件来构建复杂的查询非常有用。虽然构建表达式树可能相对复杂,但它提供了极大的灵活性和可扩展性,使我们能够根据需要动态地生成和执行代码。