Expression.Call - 调用linq扩展名:FirstOrDefault,Where

问题描述 投票:6回答:1

我试图动态创建以下,但是我在调​​用扩展方法FirstOrDefault时遇到问题:

 using(var context = new Entities())
 {
     var list = context.Engines.Include("Cars").Select(e => e.Cars.FirstOrDefault()).ToList();
 }

我有以下内容

Expression parameter = Expression.Parameter(typeof(Engine), "e");
Expression property = Expression.Property(parameter, "Cars");
  • parameter = {e}
  • property = {e.Cars}

这些都很好,但是当我尝试调用FirstOrDefault方法时遇到问题:

var result = Expression.Call(typeof(Queryable), "FirstOrDefault", new type[] { typeof(Car)}, property);

我想得到

  • 结果= {e.Cars.FirstOrDefault()}

但我得到了一个InvalidOperationException

类型'System.Linq.Queryable'上没有通用方法'FirstOrDefault'与提供的类型参数和参数兼容。如果方法是非泛型的,则不应提供类型参数。

任何帮助将非常感激。

c# linq expression dynamic predicate
1个回答
12
投票

你确定e.CarsIQueryable<T>吗?

如果没有,你不能将它传递给Queryable.FirstOrDefault<T>(IQueryable<T>)

如果它是IEnumerable<T>,请更改您的代码以调用Enumerable.FirstOrDefault<T>(IEnumerable<T>)

 var result =
     Expression.Call(
         typeof(Enumerable),
         "FirstOrDefault",
         new Type[] { TypeSystem.GetElementType(property.Type) },
         property);
© www.soinside.com 2019 - 2024. All rights reserved.