借助System.Linq.Dynamic, IQueryable根据排序字符串排序


在使用Entity Framework时,若有多个排序,需要OrderBy (OrderByDescending)再ThenBy (ThenByDescending)

假设需要根据Name升序排序,再根据Id降序排序,则:

using (EFContext<Member> context = new EFContext<Member>()) { var lst = context.Table.OrderBy(m => m.Name).ThenByDescending(e => e.Id).ToList(); foreach (var item in lst) { Console.WriteLine("name:{0}, Id:{1}",item.Name,item.Id); } }

借助System.Linq.Dynamic的方式

首先需要在项目中引用System.Linq.Dynamic,可以借助Nuget工具添加引用

引入命名空间System.Linq.Dynamic

using System.Linq.Dynamic;

修改上面的代码,

using (EFContext<Member> context = new EFContext<Member>()) { var lst = context.Table.OrderBy("Name asc,Id desc").ToList(); foreach (var item in lst) { Console.WriteLine("name:{0}, Id:{1}",item.Name,item.Id); } }

此处可以看到,OrderBy()方法传入的是排序字符串

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM