我有一个泛型类,它的方法需要对泛型实体进行排序。
但是,由于GetProperty不能转换,因此会出现一个错误,说明它不能识别反射lambda方法。
我如何做这个排序逻辑?
public IEnumerable<TEntity> GetAll()
{
var obj = _repository.GetAll()
.OrderByDescending(x => x.GetType().GetProperty(typeof(TEntity).Name + "Id"));
return obj.Pagination();
}以下是错误图像:

发布于 2017-06-24 14:12:40
这个错误说明了一切。
Linq to Entities不知道如何将x.GetType().GetProperty(typeof(TEntity).Name + "Id")转换成SQL。
您可以首先物化结果,因此它将是linq to objects:
_repository.GetAll().ToList()
.OrderByDescending(x => x.GetType().GetProperty(typeof(TEntity).Name + "Id"));发布于 2017-06-25 11:38:57
您可以使用_repository.GetAll().Queryable().OrderByDescending(x => x.GetType().GetProperty(typeof(TEntity).Name + "Id"));
发布于 2017-06-25 13:53:10
若要动态生成LINQ查询,请使用Expression Trees。您的方法可能如下所示:
public IEnumerable<TEntity> GetAll()
{
IQueryable<TEntity> obj = _repository.GetAll();
PropertyInfo keyProperty = typeof(TEntity).GetProperty(string.Concat(typeof(TEntity).Name, "Id"));
Expression parameter = Expression.Parameter(typeof(TEntity));
Expression predicate = Expression.Lambda(Expression.Property(parameter, keyProperty), parameter);
Expression queryExpression = Expression.Call(typeof(Queryable), "OrderByDescending", new Type[] { typeof(TEntity), keyProperty.PropertyType }, obj, predicate);
obj = obj.Provider.CreateQuery<TEntity>(queryExpression);
return obj.Pagination();
}https://stackoverflow.com/questions/44733229
复制相似问题