我正在尝试编写一个可重用的linq表达式,我将多个参数传递到:
private System.Linq.Expressions.Expression<Func<FeeDetail, FeeDetail, bool>> IsPrevFeeDetail
{
get
{
return (feeLevelDetail, currentFeeLevelDetail) =>
feeLevelDetail.ToDt < currentFeeLevelDetail.FromDt);
}
}
但是我看到的每个表达式示例只有一个参数(您要查询的实体类型)。
有没有办法开箱即用?
答案 0 :(得分:3)
我在回答时的问题只是询问是否可以使用具有多个参数的表达式。它们可以使用,并且是。
.Join
和.GroupJoin
都有一个表达式参数,作为最后一个参数,它接受从连接的每一侧派生的类型并返回单个实体并返回单个类型。
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查询函数都会将单个类型的集合作为返回。您已经在上面看到,我基本上将2个实体的连接转换为单一类型的输出。我使用过匿名类型,但注意这也可能是一个具体的类型,然后你可以把它放在一个可重用的连接表达式中,然后你得到一个单输入表达式可能会有所帮助你可以传递给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);
我不确定,但我不相信这会对非原语有效,因为LINQ-to-SQL可能无法解析结果表达式。