Expressionable:
Expressionable
是一个工具类,通常用于动态构建 LINQ 表达式。它允许开发者根据不同的条件生成不同的表达式,从而实现更加灵活的查询和数据操作。
在很多场景下,我们需要根据用户输入的查询条件来生成不同的数据库查询。这些条件可能是可选的,或者根据上下文需要进行动态组合。Expressionable
可以简化这种动态条件的生成过程,避免编写复杂的嵌套逻辑。
Expressionable
提供了一些常用方法,例如:
Create<T>()
: 创建一个用于构建表达式的基础对象,其中T
是目标实体类。AndIF(condition, expression)
: 根据条件(condition
)的结果决定是否将表达式(expression
)加入到当前的表达式树中。用于在满足条件时添加查询条件。ToExpression()
: 将构建好的表达式树转换为可执行的 LINQ 表达式。
var predicate = Expressionable.Create<Sys_Users>();
predicate = predicate.AndIF(!string.IsNullOrEmpty(parm.QueryText),
m => m.UserID.Contains(parm.QueryText) || m.UserName.Contains(parm.QueryText));
var queryExpression = predicate.ToExpression();
这里,如果 parm.QueryText
不为空,表达式将会生成一个查询条件(模糊查询)来匹配 UserID
或 UserName
包含 QueryText
的记录。
LINQ 表达式
LINQ(Language-Integrated Query) 是 .NET 中用于数据查询的一个功能,它提供了一种一致的方法来查询各种数据源(如集合、数据库、XML 等)。LINQ 表达式是一个 C# 语言内置的查询语言,它将查询直接嵌入到 C# 或 VB.NET 代码中。
LINQ 表达式的核心概念
-
Lambda 表达式: 用于定义匿名函数,可以传递给 LINQ 方法来创建查询。
x => x > 10
上面的 lambda 表达式表示一个条件,测试
x
是否大于 10。 -
表达式树(Expression Tree): 表达式树表示代码的抽象语法树,可以在运行时分析和修改。通过表达式树,可以在运行时动态生成和执行代码。
Expression<Func<int, bool>> expression = x => x > 10;
-
LINQ 查询方法: 常用的 LINQ 方法如
Where
,Select
,OrderBy
,GroupBy
等,用于对数据进行筛选、排序、分组和投影等操作。var results = users.Where(u => u.Age > 18).Select(u => u.Name);
LINQ 表达式的优势
- 统一性: 支持多种数据源(如数据库、集合、XML 等)的查询操作,语法一致。
- 类型安全: 编译时检查,可以避免 SQL 注入攻击。
- 可读性: 使用 C# 语言的语法嵌入查询,使代码更具可读性和可维护性。
LINQ 表达式示例
下面的代码使用 LINQ 查询一个用户集合,查找所有用户名包含 "John" 的用户:
List<User> users = GetUsers();
var query = users.Where(u => u.UserName.Contains("John")).ToList();
这里的 u => u.UserName.Contains("John")
是一个 Lambda 表达式,用于定义过滤条件。LINQ 将该条件应用于用户集合,返回满足条件的用户列表。