借助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()方法传入的是排序字符串
相关推荐
Morelia 2020-11-03
love0u 2020-08-16
xiaouncle 2020-07-31
踩风火轮的乌龟 2020-07-26
THEEYE 2020-06-25
DAV数据库 2020-06-17
lightlanguage 2020-06-13
kuoying 2020-06-07
地下库 2020-05-29
HappyHeng 2020-05-28
lysanderK 2020-05-26
Caleb0 2020-05-08
boredbird 2020-05-06
<add key="RedisPath" value="127.0.0.1:6379"/> todo:这里配置自己redis的ip地址和端口号。//ReadServerList:可读的Redis链接地
天空一样的蔚蓝 2020-05-05
cyydjt 2020-05-04
TyCoding 2020-05-03