微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 具有动态排序的LINQ查询

我有一个查询,我需要有一个基于querystring参数的ordeby.例如,如果sortby参数是price,Query需要随价格变化.如果其评级比改变查询按评级排序.

我知道PredicateBuilder可以做和OR的东西,但是如何做一个动态的ordeby linq查询.

解决方法

那么你可以使用switch语句或类似的东西:
IQueryable<Foo> query = ...;

switch (orderByParameter)
{
    case "price":
        query = query.OrderBy(x => x.Price);
        break;
    case "rating":
        query = query.OrderBy(x => x.rating);
        break;
    // etc
}

你也可以用反思来做,但假设你有一定数量的字段来排序,这可能是最简单的方法.

原文地址:https://www.jb51.cc/csharp/95712.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐