当前位置: 首页 > news >正文

【C# 基础精讲】LINQ 基础

在这里插入图片描述

LINQ(Language Integrated Query)是一项强大的C#语言特性,它使数据查询和操作变得更加简洁、灵活和可读性强。通过使用LINQ,您可以使用类似SQL的语法来查询各种数据源,如集合、数组、数据库等。本文将介绍LINQ的基础概念、常见的LINQ操作和示例,以及如何在C#中利用LINQ进行数据查询和处理。

1. LINQ的基本概念

LINQ是一种在C#中集成的查询语言,它允许开发者使用统一的语法来查询和操作各种数据源,无论是集合还是数据库。通过LINQ,您可以在代码中编写查询表达式,而不必关心底层数据源的结构。

LINQ提供了以下主要组件:

  • 查询表达式(Query Expression):使用类似SQL的语法编写查询,以从数据源中检索所需的数据。

  • 标准查询运算符(Standard Query Operators):一组内置的方法,用于在查询中执行过滤、排序、投影、分组等操作。

  • 延迟执行(Deferred Execution):查询只在实际需要数据时才执行,这有助于提高性能和节省资源。

2. 常见的LINQ操作

以下是一些常见的LINQ操作和示例:

2.1 查询操作

通过from关键字指定数据源,使用where关键字进行过滤,使用select关键字进行投影:

var result = from student in studentswhere student.Age > 18select student.Name;

2.2 方法语法

使用方法链式调用标准查询运算符,如WhereSelectOrderBy等:

var result = students.Where(student => student.Age > 18).Select(student => student.Name);

2.3 排序

使用OrderByOrderByDescending进行升序或降序排序:

var sortedStudents = students.OrderBy(student => student.Age);

2.4 分组

使用GroupBy根据指定属性进行分组:

var groupedStudents = students.GroupBy(student => student.Department);

2.5 连接

使用Join将两个数据源连接起来:

var joinedData = from student in studentsjoin course in courses on student.CourseId equals course.Idselect new { student.Name, course.CourseName };

2.6 聚合

使用SumAverageCount等进行数据聚合:

var totalAge = students.Sum(student => student.Age);
var averageAge = students.Average(student => student.Age);
var studentCount = students.Count();

2.7 延迟执行

LINQ查询的执行会被延迟,直到实际需要结果。这意味着您可以在查询中定义多个操作,而不必担心性能问题。

3. LINQ的示例

以下是一个使用LINQ查询对学生集合进行操作的示例:

using System;
using System.Collections.Generic;
using System.Linq;class Student
{public string Name { get; set; }public int Age { get; set; }public string Department { get; set; }public int CourseId { get; set; }
}class Course
{public int Id { get; set; }public string CourseName { get; set; }
}class Program
{static void Main(string[] args){List<Student> students = new List<Student>{new Student { Name = "Alice", Age = 20, Department = "Math", CourseId = 1 },new Student { Name = "Bob", Age = 22, Department = "Physics", CourseId = 2 },new Student { Name = "Carol", Age = 19, Department = "Math", CourseId = 1 },new Student { Name = "David", Age = 21, Department = "Chemistry", CourseId = 3 }};List<Course> courses = new List<Course>{new Course { Id = 1, CourseName = "Calculus" },new Course { Id = 2, CourseName = "Mechanics" },new Course { Id = 3, CourseName = "Organic Chemistry" }};var mathStudents = from student in studentswhere student.Department == "Math"select student.Name;var averageAge = students.Average(student => student.Age);var joinedData = from student in studentsjoin course in courses on student.CourseId equals course.Idselect new { student.Name, course.CourseName };Console.WriteLine("Math students:");foreach (var studentName in mathStudents){Console.WriteLine(studentName);}Console.WriteLine("Average age: " + averageAge);Console.WriteLine("Joined data:");foreach (var data in joinedData){Console.WriteLine($"{data.Name} - {data.CourseName}");}}
}

在上述示例中,我们使用LINQ查询对学生集合进行了多个操作,包括过滤、连接和聚合。通过LINQ,我们能够以一种更简洁的方式来进行数据操作。

4. 总结

LINQ是C#中的一个强大工具,它提供了一种统一的语法来查询和操作各种数据源。通过使用查询表达式或方法语法,您可以在代码中轻松地进行数据过滤、排序、分组、连接和聚合等操作。利用LINQ,您可以写出更具可读性和维护性的代码,从而提高开发效率和代码质量。无论是处理集合数据还是与数据库交互,掌握LINQ都是成为一个更高效C#开发者的关键一步。

http://www.lryc.cn/news/132794.html

相关文章:

  • ChatGPT成为工作工具,具体都应用在哪些地方?
  • Shader学习(三)(片元着色器)
  • 谷歌推出首款量子弹性 FIDO2 安全密钥
  • 前端常用的三种加密方式(MD5、base64、sha.js)
  • alpine镜像时区设置
  • Java导入Excel,保留日期格式为文本格式
  • uploadifive php上传进度条插件 解决动态传参数问题
  • Lombok生成的Getter和Setter的名称对于“eMail”或“xAxis”等属性存在大小写转换异常
  • Redis基础概念和数据类型详解
  • C语言之extern “C“详解与使用方法
  • C++中的运算符总结(4):逻辑运算符(下)
  • CloudQuery实战 | 谁说没有一款一体化数据库操作管控云平台了?
  • 如何编写一个通用的函数?
  • uni-app封装api请求
  • 深度学习从入门到实际项目资料汇总
  • 单元测试到底是什么?应该怎么做?
  • JavaWeb-Listener监听器
  • js数组常用的方法(总结)
  • Linux:shell脚本:基础使用(5)《正则表达式-sed工具》
  • 关于ubuntu下面安装cuda不对应版本的pyTorch
  • 【SA8295P 源码分析】26 - QNX Ethernet MAC 驱动 之 emac_rx_thread_handler 数据接收线程 源码分析
  • 70 # 协商缓存的配置:通过修改时间
  • 适合程序员的DB性能测试工具 JMeter
  • java实现人物关系抽取
  • Docker网络与资源控制
  • 图片怎么转换成pdf格式?可以试试这样转换
  • [国产MCU]-W801开发实例-GPIO输入与中断
  • Layui列表表头去掉复选框改为选择
  • Flutter实战·第二版-第三章 基础组件笔记
  • 一文彻底理解时间复杂度和空间复杂度(附实例)