繁体   English   中英

如何用多个参数制作 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都有一个表达式参数,它接受从连接的每一侧派生的类型并返回单个实体并返回单个类型。

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可能无法解析结果表达式。

Expression<Func<T, bool>> filter = q => q.PartitionKey.Equals("1998") 
&& q.RowKey.Equals("Movie-775");

(或者)

Expression<Func<T, bool>> filter = q => q.PartitionKey.Equals("1998");
filter = filter.And(q => q.RowKey.Equals("Movie-775"));

(或者)

IEnumerable<Expression<Func<T, bool>>>? filters; // Collection of expressions.
var filter = filters.First();
filters.Skip(1).ToList().ForEach(x => { filter = filter.And(x); });

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM