对数据排序 (C#)
排序操作基于一个或多个属性对序列的元素进行排序。 第一个排序条件对元素执行主要排序。 通过指定第二个排序条件,您可以对每个主要排序组内的元素进行排序。
重要
这些示例使用 System.Collections.Generic.IEnumerable<T> 数据源。 基于 System.Linq.IQueryProvider 的数据源使用 System.Linq.IQueryable<T> 数据源和表达式树。 表达式树对允许的 C# 语法有限制。 此外,每个 IQueryProvider
数据源(如 EF Core)可能会施加更多限制。 查看数据源的文档。
下图展示了对一系列字符执行按字母顺序排序操作的结果。
下节列出了对数据进行排序的标准查询运算符方法。
方法
方法名 | 描述 | C# 查询表达式语法 | 更多信息 |
---|---|---|---|
OrderBy | 按升序对值排序。 | orderby |
Enumerable.OrderBy Queryable.OrderBy |
OrderByDescending | 按降序对值排序。 | orderby … descending |
Enumerable.OrderByDescending Queryable.OrderByDescending |
ThenBy | 按升序执行次要排序。 | orderby …, … |
Enumerable.ThenBy Queryable.ThenBy |
ThenByDescending | 按降序执行次要排序。 | orderby …, … descending |
Enumerable.ThenByDescending Queryable.ThenByDescending |
Reverse | 反转集合中元素的顺序。 | 不适用。 | Enumerable.Reverse Queryable.Reverse |
注意
本文中的以下示例使用此区域的常见数据源。
每个 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; }
}
主要升序排序
以下示例演示如何在 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);
}
主要降序排序
下一个示例演示如何在 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);
}
次要升序排序
下面的示例演示了如何在 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}");
}
次要降序排序
下面的示例演示如何在 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}");
}