C#中的LINQ(Language-Integrated Query)

2024-04-26 08:52

本文主要是介绍C#中的LINQ(Language-Integrated Query),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

C#中的LINQ(Language-Integrated Query)是一种强大的查询语言和查询操作符集合,用于对各种数据源(如集合、数组、数据库等)进行查询、筛选、排序和转换操作。LINQ提供了一种统一的语法和编程模型,使得数据查询和处理变得更加简洁、可读性更高。

下面是LINQ的几种常见用法及其详细解释和示例:

  1. 查询语法(Query Syntax):
    查询语法使用类似于SQL的语法,通过关键字(如fromwhereselect等)来描述查询操作。它能够对数据源进行筛选、投影、排序等操作。

    示例:

    int[] numbers = { 1, 2, 3, 4, 5, 6 };
    var evenNumbers = from num in numberswhere num % 2 == 0select num;
    foreach (var num in evenNumbers)
    {Console.WriteLine(num);
    }
    // 输出:2 4 6
    
  2. 方法语法(Method Syntax):
    方法语法使用扩展方法和操作符来对数据源进行查询操作。它以方法链的形式进行调用,每个方法代表一个查询操作。

    示例:

    int[] numbers = { 1, 2, 3, 4, 5, 6 };
    var evenNumbers = numbers.Where(num => num % 2 == 0);
    foreach (var num in evenNumbers)
    {Console.WriteLine(num);
    }
    // 输出:2 4 6
    
  3. Lambda 表达式:
    Lambda 表达式用于定义匿名函数,常用于 LINQ 查询中的条件筛选和投影操作。

    示例:

    int[] numbers = { 1, 2, 3, 4, 5, 6 };
    var evenNumbers = numbers.Where(num => num % 2 == 0);
    foreach (var num in evenNumbers)
    {Console.WriteLine(num);
    }
    // 输出:2 4 6
    
  4. 延迟执行(Deferred Execution):
    LINQ 查询具有延迟执行的特性,即查询不会立即执行,而是在结果被枚举或显式调用执行操作时才执行。

    示例:

    int[] numbers = { 1, 2, 3, 4, 5, 6 };
    var query = numbers.Where(num => num % 2 == 0);
    numbers[0] = 10;
    foreach (var num in query)
    {Console.WriteLine(num);
    }
    // 输出:10 2 4 6
    
  5. 连接查询(Join Query):
    连接查询用于将多个数据源进行关联,并对关联结果进行查询操作。

    示例:

    var students = new List<Student>
    {new Student { Id = 1, Name = "Alice", Age = 20 },new Student { Id = 2, Name = "Bob", Age = 22 },new Student { Id = 3, Name = "Charlie", Age = 21 }
    };var scores = new List<Score>
    {new Score { StudentId = 1, Subject = "Math", Grade = 80 },new Score { StudentId = 2, Subject = "Math", Grade = 90 },new Score { StudentId = 3, Subject = "Math", Grade = 85 }
    };var query = from student in studentsjoin score in scores on student.Id equals score.StudentIdwhere score.Grade >= 85select new { student.Name, score.Subject };foreach (var result in query)
    {Console.WriteLine($"{result.Name} - {result.Subject}");
    }
    // 输出:Alice - Math
    //       Bob - Math
    
  6. 分组查询(Grouping Query):
    分组查询用于将数据源按照指定的键进行分组,并对每个组进行聚合或查询操作。

    示例:

    var students = new List<Student>
    {new Student { Id = 1, Name = "Alice", Age = 20 },I apologize for the incomplete response. Here are a few more examples of LINQ usage in C#:
  7. 聚合函数(Aggregate Functions):
    聚合函数用于对数据源进行聚合操作,如计算总和、平均值、最大值、最小值等。

    示例:

    int[] numbers = { 1, 2, 3, 4, 5 };
    int sum = numbers.Sum();
    int max = numbers.Max();
    int min = numbers.Min();
    double average = numbers.Average();Console.WriteLine($"Sum: {sum}");             // 输出:Sum: 15
    Console.WriteLine($"Max: {max}");             // 输出:Max: 5
    Console.WriteLine($"Min: {min}");             // 输出:Min: 1
    Console.WriteLine($"Average: {average}");     // 输出:Average: 3
    
  8. 排序(Sorting):
    使用 OrderByOrderByDescending 方法对数据进行排序。

    示例:

    int[] numbers = { 5, 2, 1, 4, 3 };
    var sortedNumbers = numbers.OrderBy(num => num);foreach (var num in sortedNumbers)
    {Console.WriteLine(num);
    }
    // 输出:1 2 3 4 5
    
  9. 转换(Projection):
    使用 Select 方法对数据进行转换,可以选择要返回的字段或进行复杂的转换操作。

    示例:

    var students = new List<Student>
    {new Student { Id = 1, Name = "Alice", Age = 20 },new Student { Id = 2, Name = "Bob", Age = 22 },new Student { Id = 3, Name = "Charlie", Age = 21 }
    };var studentNames = students.Select(student => student.Name);foreach (var name in studentNames)
    {Console.WriteLine(name);
    }
    // 输出:Alice Bob Charlie
    

这些示例涵盖了LINQ的一些常见用法,包括查询语法、方法语法、Lambda表达式、延迟执行、连接查询、分组查询、聚合函数、排序和转换。通过利用LINQ的强大功能,可以简化和提高数据处理和查询的效率。

这篇关于C#中的LINQ(Language-Integrated Query)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/937136

相关文章

使用C#删除Excel表格中的重复行数据的代码详解

《使用C#删除Excel表格中的重复行数据的代码详解》重复行是指在Excel表格中完全相同的多行数据,删除这些重复行至关重要,因为它们不仅会干扰数据分析,还可能导致错误的决策和结论,所以本文给大家介绍... 目录简介使用工具C# 删除Excel工作表中的重复行语法工作原理实现代码C# 删除指定Excel单元

C#使用MQTTnet实现服务端与客户端的通讯的示例

《C#使用MQTTnet实现服务端与客户端的通讯的示例》本文主要介绍了C#使用MQTTnet实现服务端与客户端的通讯的示例,包括协议特性、连接管理、QoS机制和安全策略,具有一定的参考价值,感兴趣的可... 目录一、MQTT 协议简介二、MQTT 协议核心特性三、MQTTNET 库的核心功能四、服务端(BR

C#继承之里氏替换原则分析

《C#继承之里氏替换原则分析》:本文主要介绍C#继承之里氏替换原则,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#里氏替换原则一.概念二.语法表现三.类型检查与转换总结C#里氏替换原则一.概念里氏替换原则是面向对象设计的基本原则之一:核心思想:所有引py

C#实现访问远程硬盘的图文教程

《C#实现访问远程硬盘的图文教程》在现实场景中,我们经常用到远程桌面功能,而在某些场景下,我们需要使用类似的远程硬盘功能,这样能非常方便地操作对方电脑磁盘的目录、以及传送文件,这次我们将给出一个完整的... 目录引言一. 远程硬盘功能展示二. 远程硬盘代码实现1. 底层业务通信实现2. UI 实现三. De

C#通过进程调用外部应用的实现示例

《C#通过进程调用外部应用的实现示例》本文主要介绍了C#通过进程调用外部应用的实现示例,以WINFORM应用程序为例,在C#应用程序中调用PYTHON程序,具有一定的参考价值,感兴趣的可以了解一下... 目录窗口程序类进程信息类 系统设置类 以WINFORM应用程序为例,在C#应用程序中调用python程序

基于C#实现MQTT通信实战

《基于C#实现MQTT通信实战》MQTT消息队列遥测传输,在物联网领域应用的很广泛,它是基于Publish/Subscribe模式,具有简单易用,支持QoS,传输效率高的特点,下面我们就来看看C#实现... 目录1、连接主机2、订阅消息3、发布消息MQTT(Message Queueing Telemetr

C#特性(Attributes)和反射(Reflection)详解

《C#特性(Attributes)和反射(Reflection)详解》:本文主要介绍C#特性(Attributes)和反射(Reflection),具有很好的参考价值,希望对大家有所帮助,如有错误... 目录特性特性的定义概念目的反射定义概念目的反射的主要功能包括使用反射的基本步骤特性和反射的关系总结特性

C#实现查找并删除PDF中的空白页面

《C#实现查找并删除PDF中的空白页面》PDF文件中的空白页并不少见,因为它们有可能是作者有意留下的,也有可能是在处理文档时不小心添加的,下面我们来看看如何使用Spire.PDFfor.NET通过C#... 目录安装 Spire.PDF for .NETC# 查找并删除 PDF 文档中的空白页C# 添加与删

通过C#获取Excel单元格的数据类型的方法详解

《通过C#获取Excel单元格的数据类型的方法详解》在处理Excel文件时,了解单元格的数据类型有助于我们正确地解析和处理数据,本文将详细介绍如何使用FreeSpire.XLS来获取Excel单元格的... 目录引言环境配置6种常见数据类型C# 读取单元格数据类型引言在处理 Excel 文件时,了解单元格

C#实现高性能Excel百万数据导出优化实战指南

《C#实现高性能Excel百万数据导出优化实战指南》在日常工作中,Excel数据导出是一个常见的需求,然而,当数据量较大时,性能和内存问题往往会成为限制导出效率的瓶颈,下面我们看看C#如何结合EPPl... 目录一、技术方案核心对比二、各方案选型建议三、性能对比数据四、核心代码实现1. MiniExcel