VB.net 2010 视频教程 VB.net 2010 视频教程 python基础视频教程
SQL Server 2008 视频教程 c#入门经典教程 Visual Basic从门到精通视频教程
当前位置:
首页 > 编程开发 > c#教程 >
  • C#教程之C#教程之借助System.Linq.Dynamic, IQueryable根据排序字

本站最新发布   C#从入门到精通
试听地址  
https://www.xin3721.com/eschool/CSharpxin3721/

在使用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()方法传入的是排序字符串

相关教程