.NET 9 中 LINQ 新增功能实现过程

ASP.NET教程 2025-08-26

目录

  • LINQ 介绍
  • .NET 9 环境准备
  • CountBy方法
  • AggregateBy方法

LINQ 介绍

语言集成查询 (LINQ) 是一系列直接将查询功能集成到 C# 语言的技术统称。 数据查询历来都表示为简单的字符串,没有编译时类型检查或 IntelliSense 支持。 此外,需要针对每种类型的数据源了解不同的查询语言:SQL 数据库、XML 文档、各种 Web 服务等。 借助 LINQ,查询成为了最高级的语言构造,就像类、方法和事件一样。

.NET 9 环境准备

需要体验 .NET 9 中 LINQ 的新增功能前提是需要安装 .NET 9 环境,安装 .NET 9 SDK 并且Visual Studio 2022需要更新至17.12版本。

  • 下载.NET 9.0:https://dotnet.*m**icrosoft.com/zh-cn/download/dotnet/9.0

CountBy方法

CountBy这个方法允许开发者按键来聚合集合中的元素,并计算每个键的出现次数。这使得计算某个数据集中特定元素的频率变得非常简单。

       public static void CountByExample()
        {
            var sourceText = "This is a test text. This is only a test. This is the best. This,This,This";
            // 统计每个单词出现的次数
            KeyValuePairstring, int mostFrequentWord = sourceText
            .Split([' ', '.', ','], StringSplitOptions.RemoveEmptyEntries)
            .Select(word = word.ToLowerInvariant())
            .CountBy(word = word)
            .MaxBy(pair = pair.Value);
            Console.WriteLine($"最常见的词是:'{mostFrequentWord.Key}' 出现次数: {mostFrequentWord.Value}");
        }

输出结果:

AggregateBy方法

AggregateBy这个方法提供了更强大的聚合功能,开发者可以定义一个聚合逻辑(如求和、平均值等),并按键进行聚合。该方法在需要基于键对集合中的元素进行复杂计算时非常有用。

       public static void AggregateByExample()
        {
            (string id, int score)[] data =
                [
                ("0", 88),
                ("1", 5),
                ("2", 4),
                ("1", 10),
                ("6", 5),
                ("4", 10),
                ("6", 25)];
            // aggregatedData 是一个序列,包含按姓名分组并计算总分的元素
            var aggregatedData =
                data.AggregateBy(
                    keySelector: entry = entry.id,
                    seed: 0,
                    (totalScore, curr) = totalScore + curr.score
                    );
            foreach (var item in aggregatedData)
            {
                Console.WriteLine(item);
            }
        }

输出结果:

IndexTSource(IEnumerableTSource)方法

借助 IndexTSource(IEnumerableTSource),可以快速提取可枚举项的隐式索引。 现在,可以编写代码(如以下代码片段)来自动为集合中的项编制索引。

       public static void IndexExample()
        {
            var lines = new Liststring { "First line", "Second line", "Third line" };
            foreach (var (index, line) in lines.Index())
            {
                Console.WriteLine($"Line {index + 1}: {line}");
            }
        }

输出结果:

参考文章

https://learn.mi*c*r*osoft.com/zh-cn/dotnet/core/whats-new/dotnet-9/overview#linq

到此这篇关于.NET 9 中 LINQ 新增功能实操的文章就介绍到这了,更多相关.NET 9 LINQ内容请搜索本站以前的文章或继续浏览下面的相关文章希望大家以后多多支持本站!

您可能感兴趣的文章:
  • asp.net使用LINQ to SQL连接数据库及SQL操作语句用法分析
  • asp.net中一个linq分页实现代码
  • asp.net中通过ALinq让Mysql操作变得如此简单
  • asp.net 根据汉字的拼音首字母搜索数据库(附 LINQ 调用方法)
  • asp.net Linq to Xml学习笔记
  • asp.net LINQ中数据库连接字符串的问题
  • asp.net Linq TO Sql 分页方法
  • asp.net Linq To Xml上手Descendants、Elements遍历节点