前端之家收集整理的这篇文章主要介绍了
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.f2er.com/csharp/95712.html