动态创建 Lambda 表达式
首先我们看一个简单 Lambda 表达式的构成。
i => i > 5
在这个表达式中,"i" 被称为 Parameter,"i > 5" 是 Body。我们可以对 Body 进行更进一步的分解,那么 "i > 5" 分别包含参数(i)、操作符(>)以及一个常数(5)。所有这些通过特定顺序的组合,从而构建一个完整的 Lambda 表达式。
我们通过一些例子,来学习如何动态构建这些表达式。
例子1
var ints = new int[] { , , , , , , , , };
//var r = ints.Where(i => i > 5); // 要实现的表达式
// 创建参数 i
var parameter = Expression.Parameter(typeof(int), "i");
// 创建常量5
var constant = Expression.Constant();
// 创建比较表达式 i > 5
var bin = Expression.GreaterThan(parameter, constant);
// 获取Lambda表达式
var lambda = Expression.Lambda<Func<int, bool>>(bin, parameter);
// 通过 Compile 方法获取 Delegate
var _r = ints.Where(lambda.Compile());
例子2
var ints = new int[] { , , , , , , , , };
// var r = ints.Where(i => i > 5 && i <= 7); // 要实现的表达式
// 创建参数 i
var parameter = Expression.Parameter(typeof(int), "i");
// 创建表达式 i > 5
var con1 = Expression.Constant();
var bin1 = Expression.GreaterThan(parameter, con1);
// 创建表达式 i <= 7
var con2 = Expression.Constant();
var bin2 = Expression.LessThanOrEqual(parameter, con2);
// 组合两个表达式
var body = Expression.And(bin1, bin2);
// 获取 Lambda 表达式
var lambda = Expression.Lambda<Func<int, bool>>(body, parameter);
var _r = ints.Where(lambda.Compile());
在例子2中,我们对复杂的表达式进行了分解,并使用 And 完成多个表达式的组装,由此我们可以创建更加复杂的逻辑组合,比如例子3。
例子3
var ints = new int[] { , , , , , , , , };
// var r = ints.Where(i => (i > 5 && i <= 7) || (i == 3)); // 要实现的表达式
// 创建参数 i
var parameter = Expression.Parameter(typeof(int), "i");
// 创建表达式 i > 5
var con1 = Expression.Constant();
var bin1 = Expression.GreaterThan(parameter, con1);
// 创建表达式 i < 7
var con2 = Expression.Constant();
var bin2 = Expression.LessThanOrEqual(parameter, con2);
// 创建表达式 i == 3
var con3 = Expression.Constant();
var bin3 = Expression.Equal(parameter, con3);
// 组合 i > 5 && i <= 7
var body = Expression.And(bin1, bin2);
// 组合 ( i > 5 && i <= 7) OR (i == 3)
body = Expression.Or(body, bin3);
var lambda = Expression.Lambda<Func<int, bool>>(body, parameter);
var _r = ints.Where(lambda.Compile());
例子4
var ints = new int[] { , , , , , , , , };
//var r = ints.Select(i => i % 2 == 0 ? i : 0); // 要实现的表达式
// 创建参数 i
var parameter = Expression.Parameter(typeof(int), "i");
// 创建表达式 i % 2
var con1 = Expression.Constant();
var bin1 = Expression.Modulo(parameter, con1);
// 创建表达式 (i % 2) == 0
var con2 = Expression.Constant();
var bin2 = Expression.Equal(bin1, con2);
// 创建表达式 IIF(((i % 2) = 0), i, 0)
var bin3 = Expression.Condition(bin2, parameter, Expression.Constant());
var lambda = Expression.Lambda<Func<int, int>>(bin3, parameter);
var _r = ints.Select(lambda.Compile());
例子5
var ints = new int[] { , , , , , , , , };
// Array.ForEach<int>(ints, i => Console.WriteLine(i)); // 要实现的表达式
// 创建参数i
var parameter = Expression.Parameter(typeof(int), "i");
// 获取 Console.WriteLine MethodInfo
MethodInfo method = typeof(Console).GetMethod("WriteLine", new Type[] { typeof(int) });
// 创建表达式
var call = Expression.Call(method, parameter);
var lambda = Expression.Lambda<Action<int>>(call, parameter);
Array.ForEach<int>(ints, lambda.Compile());
动态创建 Lambda 表达式的更多相关文章
- 动态创建Lambda表达式实现高级查询
需求简介 最近这几天做的东西总算是回归咱的老本行了,给投资管理项目做一个台账的东西,就是类似我们的报表.其 中有一个功能是一个高级查询的需求,在查询条件方面大概有7.8个查询条件.需求就是如果一个条件 ...
- C#动态创建lambda表达式
/// <summary> /// 创建lambda表达式:p=>true /// </summary> /// <typeparam name="T&q ...
- 使用Expression动态创建lambda表达式
using System;using System.Linq.Expressions;using System.Reflection; namespace Helper{ public class L ...
- 动态组合lambda 表达式
//记录实体集合—动态组合lambda 表达式 Expression<Func<AdEntity, bool>> thirdWhere = p => p.Observer ...
- easyui datagrid remoteSort的实现 Controllers编写动态的Lambda表达式 IQueryable OrderBy扩展
EF 结合easy-ui datagrid 实现页面端排序 EF动态编写排序Lambda表达式 1.前端页面 var mainListHeight = $(window).height() - 20; ...
- 【转】EntityFramework动态组合Lambda表达式作为数据筛选条件,代替拼接SQL语句
传统的操作数据库方式,筛选数据需要用StringBuilder拼接一大堆的WHERE子句. 在Entity Framework中,代码稍有不慎就会造成巨大性能消耗,如: using(var db=ne ...
- 动态拼接lambda表达式树
前言 最近在优化同事写的代码(我们的框架用的是dapperLambda),其中有一个这样很普通的场景——界面上提供了一些查询条件框供用户来进行过滤数据.由于dapperLambda按条件查询时是传入表 ...
- [2014-12-30]如何动态构造Lambda表达式(动态构造Lambda查询条件表达式)
声明 本文对Lambda表达式的扩展,示例代码来源于网络. 场景描述 web开发查询功能的时候,如果查询条件比较多,就会遇到动态组合查询条件的情况.在手写sql的情况下,我们一般会根据传入的参数,针对 ...
- 动态构建Lambda表达式实现EF动态查询
在使用Entity Framework做数据查询的时候,查询条件往往不是固定的,需要动态查询.可以通过动态构建Lamda表达式来实现动态查询. Lamda表达式 使用Lamda表达式可以很方便的按条件 ...
随机推荐
- 浅谈JavaScript、ES5、ES6
// http://es6.ruanyifeng.com/#docs/intro (ES6 文档) 什么是JavaScript JavaScript一种动态类型.弱类型.基于原型的客户端脚本语言,用来 ...
- PHP中Exception异常
异常的基本使用 当异常被抛出时,其后的代码不会继续执行,PHP 会尝试查找匹配的 "catch" 代码块. 如果异常没有被捕获,而且又没用使用 set_exception_hand ...
- mysql获取一个表中的下一个自增(id)值的方法
SELECT Auto_increment FROM information_schema.`TABLES` WHERE Table_Schema='数据库名' AND table_name = '表 ...
- DataGrid控件使用
应用Binding显示后台数据 <UserControl x:Class="demo03.View.UserInfoList" xmlns=" ...
- SQL Server数据库SP命令祥解
1.数据库: (1)sp_helpdb:报告有关指定数据库或所有数据库的信息.例:sp_helpdb --显示所有数据库信息(名称.大小等)例:sp_helpdb Recruitment -- ...
- Linux vmstat使用
Vmstat命令的简单使用 Vmstat命令是Linux/unix常用的系统监控工具,可以方便的查看CPU.内存.swap分区.IO读写等情况. Vmstat常用的参数主要有两个:1.采集的时间间隔 ...
- 【转】将Oracle数据库设置为归档模式
查看归档状态为非归档sys@JSSBOOK> select log_mode from v$database;LOG_MODE------------NOARCHIVELOG archive状态 ...
- Java中Runnable和Thread的区别
在java中可有两种方式实现多线程,一种是继承Thread类,一种是实现Runnable接口:Thread类是在java.lang包中定义的.一个类只要继承了Thread类同时覆写了本类中的run() ...
- git用法之常用命令
1.git 安装好后,如何配置? a: 设置本地用户名.邮箱,很重要!之后的每次提交都会用到这两条信息,说明是谁提交了更新. $ git config --global user.name " ...
- 页面解耦—— 统跳协议和Rewrite引擎
原文: http://pingguohe.net/2015/11/24/Navigator-and-Rewrite.html 解耦神器 —— 统跳协议和Rewrite引擎 Nov 24, 2015 • ...