动态创建Lambda表达式实现高级查询


   需求简介


   最近这几天做的东西总算是回归咱的老本行了,给投资管理项目做一个台账的东西,就是类似我们的报表。其


中有一个功能是一个高级查询的需求,在查询条件方面大概有7、8个查询条件。需求就是如果一个条件都不输入就默


认查询全部的数据,那个条件不为空的时候就在查询条件上面添加对响应字段的限制,也就是说我们在写查询条件的


时候不能写死,因为我们不知道我们到底有几个条件?到底有几个条件。所以需要我们动态的创建Lambd表达式。看


了看他们相似的功能,在实现的时候用的动态拼接SQL语句,那些SQL代码啊?看到都头疼,所以我直接放弃了,用咱


自己熟悉的知识来实现。和这个相似的功能自己在之前的《图书馆项目》中实现过,请点击我


   具体实现—小Demo


   首先需要引入命名空间


   using System.Linq.Expressions.Expression;


   

//创建一个数组用来当做例子


   var ints = new int []{ 1, 2 , 3 , 4 , 5 , 6 };


   // 要创建形如 i => i < 5


   //创建参数 i


var parameter  = Expression.Parameter(typeof(int),”i”);


//创建常数 5


var constant = Expression.Constant(5);


//创建 i > 5


var bin = Expression.GreaterThan(parameter,constant);


//获取Lambda表达式


var lambda=Expression.Lambda<Func<Int32,Boolean>>(bin,parameter);


//取得查询结果


var query = ints.Where(lambda.Compile());


   通过上面一个小Demo我们可以简单的看到动态创建Lambda表达式的雏形,下面在介绍一个比较复杂的例子。


BinaryExpression condition = null;

//要构造的表达式i==1||i==2||i==3.....

for (int i = 0; i < ints.Length; i++)

{

      ConstantExpression ce = Expression.Constant(i);

      if (condition == null)

      {

           condition = Expression.Equal(parameter, ce);

      }

      else

      {

           var right = Expression.Equal(parameter, ce);

           condition = Expression.Or(condition, right);

      }

}

Expression<Func<Int32, Boolean>> lambda =
  • 4
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 62
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 62
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

g-Jack

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值