c# – Linq从字符串排序方向

前端之家收集整理的这篇文章主要介绍了c# – Linq从字符串排序方向前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试对一组用户进行排序.我可以访问排序属性和方向(asc,desc).我目前的查询订单如下.但正如您所看到的那样,它并未考虑排序方向.如何在不必使用Dynamic Linq或为“asc”或“desc”排序方向添加另一组语句的情况下构建此表达式.
  1. public override IQueryable<DalLinq.User> GetSort(IQueryable<DalLinq.User> query)
  2. {
  3. //SelectArgs.SortDirection <- Sort Direction
  4. switch (SelectArgs.SortProperty)
  5. {
  6. case "LastName":
  7. query = query.OrderBy(p => p.LastName);
  8. break;
  9. case "FirstName":
  10. query = query.OrderBy(p => p.FirstName);
  11. break;
  12. default:
  13. query = query.OrderBy(p => p.UserName);
  14. break;
  15. }
  16.  
  17. return query;
  18. }

解决方法

理想情况下,您想使用OrderByDescending – 您当然可以作弊:
  1. public static class MyExtensionMethods
  2. {
  3. public static IOrderedQueryable<TSource> OrderBy<TSource,TValue>(
  4. this IQueryable<TSource> source,Expression<Func<TSource,TValue>> selector,bool asc)
  5. {
  6. return asc ? source.OrderBy(selector) : source.OrderByDescending(selector);
  7. }
  8. }

并使用OrderBy传递选择器和bool?

如果你不需要静态类型,你也可以从头开始动态构建表达式 – 当然 – 比如this short sample(类似于动态LINQ库).

猜你在找的C#相关文章