组合表达式列表中的表达式

npp*_*tel 3 c# expression dynamic

我想使用 LINQ to SQL 创建动态查询生成器

为此,我创建了我的界面,将每个动态条件添加到

List<Expression<Func<T,bool>>>
Run Code Online (Sandbox Code Playgroud)

界面看起来像:

public interface IExpression<T>
{
    IExpression<T> AddWhere(Expression<Func<T,bool>> whereCriteria);    
}
Run Code Online (Sandbox Code Playgroud)

现在我想将列表中的所有表达式组合起来,并用“and”条件构造 where 子句并执行查询。

我尝试组合表达式但没有成功。

任何人都可以帮忙吗?或者请建议任何其他选择。

Lua*_*aan 6

最简单的方法是使用 PredicateBuilder:http : //www.albahari.com/nutshell/predicatebuilder.aspx

基本上,您所要做的就是使用这个辅助类:

using System;
using System.Linq;
using System.Linq.Expressions;
using System.Collections.Generic;

public static class PredicateBuilder
{
  public static Expression<Func<T, bool>> True<T> ()  { return f => true;  }
  public static Expression<Func<T, bool>> False<T> () { return f => false; }

  public static Expression<Func<T, bool>> Or<T> (this Expression<Func<T, bool>> expr1,
                                                      Expression<Func<T, bool>> expr2)
  {
    var invokedExpr = Expression.Invoke (expr2, expr1.Parameters.Cast<Expression> ());
    return Expression.Lambda<Func<T, bool>>
          (Expression.OrElse (expr1.Body, invokedExpr), expr1.Parameters);
  }

  public static Expression<Func<T, bool>> And<T> (this Expression<Func<T, bool>> expr1,
                                                       Expression<Func<T, bool>> expr2)
  {
    var invokedExpr = Expression.Invoke (expr2, expr1.Parameters.Cast<Expression> ());
    return Expression.Lambda<Func<T, bool>>
          (Expression.AndAlso (expr1.Body, invokedExpr), expr1.Parameters);
  }
}
Run Code Online (Sandbox Code Playgroud)

然后你可以像这样使用它:

  public static Expression<Func<Product, bool>> ContainsInDescription (
                                                params string[] keywords)
  {
    var predicate = PredicateBuilder.False<Product>();
    foreach (string keyword in keywords)
    {
      string temp = keyword;
      predicate = predicate.Or (p => p.Description.Contains (temp));
    }
    return predicate;
  }
Run Code Online (Sandbox Code Playgroud)

(代码和示例均取自上面的链接,我只是将其发布在这里以防链接有时不起作用)。

由于您的界面不使用泛型,因此您的特定场景有些复杂。您能否展示更多相关代码,以便我可以帮助您更好地根据您的实际需求定制此解决方案?