繁体   English   中英

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

[英]Expression.Call - Calling linq extension: FirstOrDefault, Where

我试图动态创建以下,但是我在调​​用扩展方法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");
  • 参数= {e}
  • property = {e.Cars}

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

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

我想得到

  • result = {e.Cars.FirstOrDefault()}

但我得到一个InvalidOperationException

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

任何帮助将非常感激。

你确定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);

暂无
暂无

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

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