Linq中的对数据排序 (C#):OrderBy、OrderByDescending、ThenBy、ThenByDescending
排序操作基于一个或多个属性对序列的元素进行排序。 第一个排序条件对元素执行主要排序。 通过指定第二个排序条件,可以对每个主要排序组内的元素进行排序。
每个 Student
都有年级、主要院系和一系列分数。 Teacher
还有一个 City
属性,用于标识教师的授课校区。 Department
有一个名称,以及对担任院系主任的 Teacher
的引用。
public enum GradeLevel { FirstYear = 1, SecondYear, ThirdYear, FourthYear }; public class Student { public required string FirstName { get; init; } public required string LastName { get; init; } public required int ID { get; init; } public required GradeLevel Year { get; init; } public required List<int> Scores { get; init; } public required int DepartmentID { get; init; } } public class Teacher { public required string First { get; init; } public required string Last { get; init; } public required int ID { get; init; } public required string City { get; init; } } public class Department { public required string Name { get; init; } public int ID { get; init; } public required int TeacherID { get; init; } }
1、主要升序排序(OrderBy)
以下示例演示如何在 LINQ 查询中使用 orderby
子句,以按姓氏以升序方式对教师数组进行排序。
IEnumerable<string> query = from teacher in teachers orderby teacher.Last select teacher.Last; foreach (string str in query) { Console.WriteLine(str); }
以下代码显示了使用方法语法编写的等效查询:
IEnumerable<string> query = teachers .OrderBy(teacher => teacher.Last) .Select(teacher => teacher.Last); foreach (string str in query) { Console.WriteLine(str); }
2、主要降序排序(OrderByDescending)
下一个示例演示如何在 LINQ 查询中使用 orderby descending
子句按姓氏以降序方式对教师进行排序。
IEnumerable<string> query = from teacher in teachers orderby teacher.Last descending select teacher.Last; foreach (string str in query) { Console.WriteLine(str); }
以下代码显示了使用方法语法编写的等效查询:
IEnumerable<string> query = teachers .OrderByDescending(teacher => teacher.Last) .Select(teacher => teacher.Last); foreach (string str in query) { Console.WriteLine(str); }
3、次要升序排序(ThenBy)
下面的示例演示了如何在 LINQ 查询中使用 orderby
子句执行主要排序和次要排序。 教师主要按城市和姓氏排序,两者均按升序排序。
IEnumerable<(string, string)> query = from teacher in teachers orderby teacher.City, teacher.Last select (teacher.Last, teacher.City); foreach ((string last, string city) in query) { Console.WriteLine($"City: {city}, Last Name: {last}"); }
以下代码显示了使用方法语法编写的等效查询:
IEnumerable<(string, string)> query = teachers .OrderBy(teacher => teacher.City) .ThenBy(teacher => teacher.Last) .Select(teacher => (teacher.Last, teacher.City)); foreach ((string last, string city) in query) { Console.WriteLine($"City: {city}, Last Name: {last}"); }
4、次要降序排序(ThenByDescending)
下面的示例演示如何在 LINQ 查询中使用 orderby descending
子句按升序执行主要排序,按降序执行次要排序。 教师主要按城市排序,其次按他们的姓氏排序。
IEnumerable<(string, string)> query = from teacher in teachers orderby teacher.City, teacher.Last descending select (teacher.Last, teacher.City); foreach ((string last, string city) in query) { Console.WriteLine($"City: {city}, Last Name: {last}"); }
以下代码显示了使用方法语法编写的等效查询:
IEnumerable<(string, string)> query = teachers .OrderBy(teacher => teacher.City) .ThenByDescending(teacher => teacher.Last) .Select(teacher => (teacher.Last, teacher.City)); foreach ((string last, string city) in query) { Console.WriteLine($"City: {city}, Last Name: {last}"); }
分类:
C#
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek “源神”启动!「GitHub 热点速览」
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· DeepSeek R1 简明指南:架构、训练、本地部署及硬件要求
· 2 本地部署DeepSeek模型构建本地知识库+联网搜索详细步骤
2021-01-09 web storage的用法
2019-01-09 使用C#WebClient类访问(上传/下载/删除/列出文件目录)
2017-01-09 ADO.NET对象模型
2017-01-09 趣味理解ADO.NET对象模型
2017-01-09 C# ToString格式大全
2017-01-09 C#中A a=new B()的意义
2017-01-09 sql中时间的一些特殊转换