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

Adu*_*cci 6 c# linq expression predicate dynamic

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

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

我有以下内容

Expression parameter = Expression.Parameter(typeof(Engine), "e");
Expression property = Expression.Property(parameter, "Cars");
Run Code Online (Sandbox Code Playgroud)
  • 参数= {e}
  • property = {e.Cars}

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

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

我想得到

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

但我得到了一个 InvalidOperationException

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

任何帮助将非常感激.

dtb*_*dtb 12

你确定e.Cars是一个IQueryable <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);
Run Code Online (Sandbox Code Playgroud)