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

标签 c# linq lambda linq-to-sql

我正在尝试编写一个可重用的 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 查询函数都会提供单一类型的集合作为返回。您在上面已经看到,我基本上已将两个实体的连接转换为单一类型的输出。我使用了匿名类型,但注意到这也可以是具体类型可能会有所帮助,然后您可以将其放入可重用的连接表达式中,然后您将获得一个可以传递给的单输入表达式一个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 可能无法解析结果表达式。

关于c# - 如何制作具有多个参数的linq表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49417519/

相关文章:

c# - C# 中的别名关键字(如 typedef)?

c# - 在 C# 中,从字符串中解析出此值的最佳方法是什么?

c# - 使用 Linq 计算 2 个日期之间的对象列表

c# - 内联组合数组 - LINQ

c# - Lambda 将递增的元素添加到列表

c# - 将表达式与运算符 && 组合

c# - 将 int 存储到 SQL,但保持前导零

C#/Oracle10g = null 与 DBNull.Value 与 String.Empty

c# - 连接来自 IQueryable 和 IList<KeyValuePair> 的数据

java - 在 lambda 表达式中分配局部变量