如何制作具有多个参数的linq表达式

How to make linq expression with multiple parameters

我正在尝试编写一个可重用的 linq 表达式,我将向其中传递多个参数:

private System.Linq.Expressions.Expression<Func<FeeDetail, FeeDetail, bool>> IsPrevFeeDetail
   {
       get
       {
           return (feeLevelDetail, currentFeeLevelDetail) =>
           feeLevelDetail.ToDt < currentFeeLevelDetail.FromDt);
       }
   }

但是我见过的每个表达式示例只接受一个参数(您要查询的实体类型)。

有什么开箱即用的方法吗?

我回答时你的问题只是询问是否可以使用具有多个参数的表达式。它们可以使用,并且是。

.Join.GroupJoin 都有一个表达式参数作为最后一个参数,该表达式参数采用从连接的每一侧派生的类型和 return 单个实体和 return单一类型。

tableA.Join(tableB, e => e.Id, e => e.TableAId, (a, b) => new {
    IsPrevFee = a.ToDt < b.FromDt,
    AEntry = a,
    BEntry = b
}).Where(e => e.IsPrevFee);

但是,从您问题中的示例来看,您似乎想在 Where 中使用它。这是行不通的,因为任何 Linq 查询函数都提供单一类型的集合作为 return。您已经在上面看到我基本上将 2 个实体的连接转换为单一类型的输出。我使用了匿名类型,但注意这也可以是具体类型可能会有所帮助,然后您可以将其放入可重用的连接表达式中,然后您可以得到一个 single-input 表达式传递给 Where 子句。

编辑评论:

您应该可以通过关闭另一个参数来创建 Expression<Func<MyEntity, bool>>。我正在即时执行此操作,因此请忽略任何琐碎的语法错误,但示例如下:

Expression<Func<MyEntity, bool>> GetMyWhereClause(int statusId)
{
    return myEntity => myEntity.StatusId == statusId;
}

用法:

var MyWhereClause = GetMyWhereClause(5);
var result = db.MyEntities.Where(MyWhereClause);

我不确定,但我认为这对 non-primitives 不起作用,因为 LINQ-to-SQL 可能无法解析结果表达式。