自学内容网 自学内容网

.NET 9.0 LINQ 完全指南:从基础到高级应用场景


 LINQ 在 .NET 9.0 中的使用方法,包括基础查询、筛选、排序、聚合等,并附上代码示例、输出结果以及现实中的实际应用场景。

  • 1. 基础查询

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);
        }
    }
}
  • 输出结果:
基础查询结果:
1
2
3
4
5
  • 适用场景:从集合中检索所有元素。
  • 不适用场景:需要对集合进行更复杂的操作,如筛选或排序。

2. 筛选(Where)


var filteredQuery = numbers.Where(n => n > 3);
Console.WriteLine("筛选结果:");
foreach (var number in filteredQuery)
{
    Console.WriteLine(number);
}
  • 输出结果:
筛选结果:
4
5
  • 适用场景:从集合中筛选出满足特定条件的元素,如筛选出所有价格超过100的商品。
  • 不适用场景:需要基于多个条件进行筛选,可能需要使用更复杂的逻辑。

3. 排序(OrderBy)


var sortedQuery = numbers.OrderBy(n => n);
Console.WriteLine("排序结果:");
foreach (var number in sortedQuery)
{
    Console.WriteLine(number);
}
  • 输出结果:
排序结果:
1
2
3
4
5
  • 适用场景:对集合中的元素进行排序,如按日期排序事件。
  • 不适用场景:需要对多个字段进行排序,可能需要使用 ThenBy。

4. 聚合(Count)


var count = numbers.Count();
Console.WriteLine("元素数量:");
Console.WriteLine(count);

输出结果:

元素数量:
5
  • 适用场景:统计集合中的元素数量,如计算用户数量。
  • 不适用场景:需要对集合中的元素进行更复杂的统计,如平均值或总和。

5. 分组(GroupBy)


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}");
    }
}
  • 输出结果:
按年龄分组结果:
Age: 30
 - 张三
 - 王五
Age: 25
 - 李四
  • 适用场景:将集合中的元素按照某个属性进行分组,如按部门分组员工。
  • 不适用场景:需要对分组后的数据进行复杂的操作,可能需要使用更高级的LINQ方法。

原文地址:https://blog.csdn.net/llyfe2006/article/details/143796285

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!