首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用GetProperty按反射排序

使用GetProperty按反射排序
EN

Stack Overflow用户
提问于 2017-06-24 13:47:08
回答 3查看 751关注 0票数 0

我有一个泛型类,它的方法需要对泛型实体进行排序。

但是,由于GetProperty不能转换,因此会出现一个错误,说明它不能识别反射lambda方法。

我如何做这个排序逻辑?

代码语言:javascript
复制
public IEnumerable<TEntity> GetAll()
{
    var obj = _repository.GetAll()
        .OrderByDescending(x => x.GetType().GetProperty(typeof(TEntity).Name + "Id"));

    return obj.Pagination();
}

以下是错误图像:

EN

回答 3

Stack Overflow用户

发布于 2017-06-24 14:12:40

这个错误说明了一切。

Linq to Entities不知道如何将x.GetType().GetProperty(typeof(TEntity).Name + "Id")转换成SQL。

您可以首先物化结果,因此它将是linq to objects:

代码语言:javascript
复制
_repository.GetAll().ToList()
    .OrderByDescending(x => x.GetType().GetProperty(typeof(TEntity).Name + "Id"));
票数 0
EN

Stack Overflow用户

发布于 2017-06-25 11:38:57

您可以使用_repository.GetAll().Queryable().OrderByDescending(x => x.GetType().GetProperty(typeof(TEntity).Name + "Id"));

票数 0
EN

Stack Overflow用户

发布于 2017-06-25 13:53:10

若要动态生成LINQ查询,请使用Expression Trees。您的方法可能如下所示:

代码语言:javascript
复制
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();
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44733229

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档