C#学习:Expressionable 和LINQ 表达式

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 不为空,表达式将会生成一个查询条件(模糊查询)来匹配 UserIDUserName 包含 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 表达式的优势
  1. 统一性: 支持多种数据源(如数据库、集合、XML 等)的查询操作,语法一致。
  2. 类型安全: 编译时检查,可以避免 SQL 注入攻击。
  3. 可读性: 使用 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 将该条件应用于用户集合,返回满足条件的用户列表。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值