LINQ 在 .NET 9.0 中的使用方法,包括基础查询、筛选、排序、聚合等,并附上代码示例、输出结果以及现实中的实际应用场景。
1. 基础查询
cs
using System;
using System.Linq;
using System.Collections.Generic;
public class Program
{
public static void Main()
{
List<int> numbers = new List<int> { 1, 2, 3, 4, 5 };
var query = from number in numbers
select number;
Console.WriteLine("基础查询结果:");
foreach (var number in query)
{
Console.WriteLine(number);
}
}
}
- 输出结果:
cs
基础查询结果:
1
2
3
4
5
- 适用场景:从集合中检索所有元素。
- 不适用场景:需要对集合进行更复杂的操作,如筛选或排序。
2. 筛选(Where)
cs
var filteredQuery = numbers.Where(n => n > 3);
Console.WriteLine("筛选结果:");
foreach (var number in filteredQuery)
{
Console.WriteLine(number);
}
- 输出结果:
cs
筛选结果:
4
5
- 适用场景:从集合中筛选出满足特定条件的元素,如筛选出所有价格超过100的商品。
- 不适用场景:需要基于多个条件进行筛选,可能需要使用更复杂的逻辑。
3. 排序(OrderBy)
cs
var sortedQuery = numbers.OrderBy(n => n);
Console.WriteLine("排序结果:");
foreach (var number in sortedQuery)
{
Console.WriteLine(number);
}
- 输出结果:
cs
排序结果:
1
2
3
4
5
- 适用场景:对集合中的元素进行排序,如按日期排序事件。
- 不适用场景:需要对多个字段进行排序,可能需要使用 ThenBy。
4. 聚合(Count)
cs
var count = numbers.Count();
Console.WriteLine("元素数量:");
Console.WriteLine(count);
输出结果:
cs
元素数量:
5
- 适用场景:统计集合中的元素数量,如计算用户数量。
- 不适用场景:需要对集合中的元素进行更复杂的统计,如平均值或总和。
5. 分组(GroupBy)
cs
List<Person> people = new List<Person>
{
new Person { Name = "张三", Age = 30 },
new Person { Name = "李四", Age = 25 },
new Person { Name = "王五", Age = 30 }
};
var groupedByAge = people.GroupBy(p => p.Age);
Console.WriteLine("按年龄分组结果:");
foreach (var group in groupedByAge)
{
Console.WriteLine($"Age: {group.Key}");
foreach (var person in group)
{
Console.WriteLine($" - {person.Name}");
}
}
- 输出结果:
cs
按年龄分组结果:
Age: 30
- 张三
- 王五
Age: 25
- 李四
- 适用场景:将集合中的元素按照某个属性进行分组,如按部门分组员工。
- 不适用场景:需要对分组后的数据进行复杂的操作,可能需要使用更高级的LINQ方法。