让Linq的OrderBy支持动态字段

使用linq的OrderBy,如果明确知道是哪个字段,当然很容易:

 IQueryable<User> userQuery = ...;
 userQuery.OrderBy(u => u.Code)

但假如我们想写一个通用方法,预先并不知道要用哪个字段排序呢?

在网上寻寻觅觅,有许多国内的博客互相抄袭,信誓旦旦,但其实那些代码都运行不了。

还是老外的好使:
http://www.4byte.cn/question/33782/dynamic-orderby-using-linq-dynamic.html

我拿来修改了一下,可以用。主要思想是扩展Queryable。但里面的东西有许多我都看不懂。

    public static class QueryableExtension
    {
        public static IOrderedQueryable<T> OrderBy<T>(this IQueryable<T> query, string propertyName)
        {
            return _OrderBy<T>(query, propertyName, false);
        }
        public static IOrderedQueryable<T> OrderByDescending<T>(this IQueryable<T> query, string propertyName)
        {
            return _OrderBy<T>(query, propertyName, true);
        }

        static IOrderedQueryable<T> _OrderBy<T>(IQueryable<T> query, string propertyName,bool isDesc)
        {
            string methodname = (isDesc) ? "OrderByDescendingInternal" : "OrderByInternal";

            var memberProp = typeof(T).GetProperty(propertyName);

            var method = typeof(QueryableExtension).GetMethod(methodname)
                                       .MakeGenericMethod(typeof(T), memberProp.PropertyType);

            return (IOrderedQueryable<T>)method.Invoke(null, new object[] { query, memberProp });
        }
        public static IOrderedQueryable<T> OrderByInternal<T, TProp>(IQueryable<T> query, PropertyInfo memberProperty)
        {//public
            return query.OrderBy(_GetLamba<T, TProp>(memberProperty));
        }
        public static IOrderedQueryable<T> OrderByDescendingInternal<T, TProp>(IQueryable<T> query, PropertyInfo memberProperty)
        {//public
            return query.OrderByDescending(_GetLamba<T, TProp>(memberProperty));
        }
        static Expression<Func<T, TProp>> _GetLamba<T, TProp>(PropertyInfo memberProperty)
        {
            if (memberProperty.PropertyType != typeof(TProp)) throw new Exception();

            var thisArg = Expression.Parameter(typeof(T));
            var lamba = Expression.Lambda<Func<T, TProp>>(Expression.Property(thisArg, memberProperty), thisArg);

            return lamba;
        }
    }

调用:

IQueryable<User> userQuery = ...;
//正序
userQuery = userQuery.OrderBy("Code");
//降序
userQuery = userQuery.OrderByDescending("Code");

转载于:https://www.cnblogs.com/leftfist/p/6808785.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用.NET中的LINQ进行动态排序可以通过使用Dynamic LINQ库来实现。Dynamic LINQ库是由Microsoft提供的一个扩展库,允许我们在运行时构建和执行动态LINQ查询。 首先,我们需要在项目中添加Dynamic LINQ库的引用,这可以通过从NuGet包管理器中安装Dynamic LINQ包来完成。 在代码中,我们可以使用OrderBy和ThenBy方法来进行动态排序。这两个方法可以接收一个字符串参数作为排序表达式。这个表达式可以是字段名称、属性名称或任何适用的表达式。 例如,假设我们有一个存储学生信息的列表,并且我们希望根据学生的年龄进行排序: ```csharp using System.Linq; using System.Linq.Dynamic; class Program { static void Main(string[] args) { List<Student> students = new List<Student>() { new Student() { Name = "Tom", Age = 20 }, new Student() { Name = "Jerry", Age = 18 }, new Student() { Name = "Alice", Age = 22 } }; Console.WriteLine("按年龄升序排序:"); var sortedStudents = students.OrderBy("Age"); foreach (var student in sortedStudents) { Console.WriteLine(student.Name); } Console.WriteLine("按年龄降序排序:"); sortedStudents = students.OrderByDescending("Age"); foreach (var student in sortedStudents) { Console.WriteLine(student.Name); } Console.ReadLine(); } } class Student { public string Name { get; set; } public int Age { get; set; } } ``` 上述代码中,我们通过字符串参数"Age"来对学生列表进行排序。OrderBy方法将按照升序对学生列表进行排序,而OrderByDescending方法将按照降序进行排序。 通过以上代码,我们可以根据需要动态指定排序的字段,并根据要求进行升序或降序排序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值