C#中的LINQ之美:优雅的数据查询与操作

devtools/2024/10/24 5:43:22/

在这里插入图片描述

LINQ(Language Integrated Query,语言集成查询)是C#中一个强大的工具,它将查询功能直接融入到语言中,使开发者能够以一种更直观、更接近自然语言的方式来操作数据。LINQ不仅能极大地提高开发效率,而且让代码变得更加简洁易读。

LINQ的语法

LINQ的语法主要分为两种:

  • 查询语法: 这种语法更接近SQL,具有很强的可读性。
  • 方法语法: 这种语法使用一系列扩展方法来实现查询,更加灵活。

查询语法示例:

var query = from person in peoplewhere person.Age > 30select person.Name;

方法语法示例:

var query = people.Where(person => person.Age > 30).Select(person => person.Name);

LINQ的工作原理

LINQ的底层实现是基于迭代器模式的。当我们执行一个LINQ查询时,它并不会立即执行,而是创建了一个表示查询的表达式树。只有当我们对查询结果进行遍历时,表达式树才会被执行,并且结果会被延迟加载。

LINQ的应用场景及示例

1. 筛选数据
int[] numbers = { 5, 4, 1, 3, 9, 8, 6, 7, 2, 0 };
var evenNumbers = numbers.Where(n => n % 2 == 0);
2. 投影数据
List<Person> people = new List<Person> { /* ... */ };
var names = people.Select(p => p.Name);
3. 排序数据
var sortedPeople = people.OrderBy(p => p.Age);
4. 分组数据
var groupedByAge = people.GroupBy(p => p.Age);
5. 聚合操作
int[] numbers = { 5, 4, 1, 3, 9, 8, 6, 7, 2, 0 };
int sum = numbers.Sum();
double average = numbers.Average();
6. 连接数据
var orders = new List<Order> { /* ... */ };
var customers = new List<Customer> { /* ... */ };
var customerOrders = orders.Join(customers,o => o.CustomerId,c => c.Id,(o, c) => new { CustomerName = c.Name, OrderTotal = o.Total }
);
7. 集合操作
var distinctNumbers = numbers.Distinct();
var union = numbers.Union(new[] { 10, 11, 12 });
8. 条件判断
bool hasAnyEvenNumber = numbers.Any(n => n % 2 == 0);
9. 数量统计
int count = people.Count(p => p.Age > 30);
10. 自定义扩展方法
public static IEnumerable<T> MyCustomFilter<T>(this IEnumerable<T> source, Func<T, bool> predicate)
{foreach (T element in source){if (predicate(element))yield return element;}
}

LINQ的优势

  • 统一的数据访问: LINQ提供了一个统一的接口来访问各种数据源,使得开发者可以专注于业务逻辑。
  • 提高代码可读性: LINQ的语法简洁明了,更容易理解。
  • 延迟执行: 延迟执行可以提高性能,避免不必要的计算。
  • 丰富的操作符: LINQ提供了一系列丰富的操作符,可以实现各种各样的数据查询和操作。
  • 集成到IDE: Visual Studio对LINQ提供了很好的支持,包括智能感知、代码提示等。

LINQ作为C#语言的一大亮点,为开发者提供了一种优雅、高效的方式来操作数据。通过学习和掌握LINQ,我们可以写出更加简洁、可读性更高的代码,提高开发效率。


http://www.ppmy.cn/devtools/128375.html

相关文章

欧盟 RED 网络安全法规 EN 18031

目录 1. &#x1f4c2; EN 18031 1.1 背景 1.2 专业术语 1.3 覆盖产品范围 1.4 EN 18031标准主要评估内容&#xff1a; 1.5 EN 18031标准主要评估项目&#xff1a; 1.6 EN 18031 与 ETSI EN 303 645 的主要差异 1.7 RED 网络安全法规解读研讨会 2. &#x1f531; EN 1…

安全见闻(7)——开阔眼界,不做井底之蛙

内容预览 ≧∀≦ゞ 安全见闻七&#xff1a;洞悉硬件设备的安全风险声明导语硬件设备的安全问题物理安全问题设备被盗或损坏环境因素电磁干扰 供应链安全问题假冒伪劣产品恶意软件植入供应链中断 设备漏洞问题操作系统漏洞固件漏洞硬件设计漏洞 网络连接问题网络攻击无线连接安全…

Windows系统PyCharm右键运行.sh文件

在参考了Windows系统下pycharm运行.sh文件&#xff0c;执行shell命令_shell在pycharm-CSDN博客 和深度学习&#xff1a;PyCharm中运行Bash脚本_pycharm bash-CSDN博客 配置了右键执行.sh文件之后&#xff0c;发现在Windows的PyCharm中直接右键运行sh文件&#xff0c;存在如下…

LeetCode 110. 平衡二叉树

给定一个二叉树&#xff0c;判断它是否是平衡二叉树。 二叉平衡树的左右子树高度相差不超过1&#xff0c;且左右子树均是二叉平衡树二叉平衡树是所有结点的左右子树高度差均不超过1的二叉树 主要考对二叉平衡树的概念 # Definition for a binary tree node. # class TreeNod…

STMicroelectronics 意法半导体芯片选型表

意法半导体作为全球知名的半导体厂商&#xff0c;其产品广泛应用于各个领域&#xff0c;从消费电子到工业控制&#xff0c;从汽车电子到通信设备&#xff0c;都能看到意法半导体芯片的身影。在电子硬件设计领域&#xff0c;芯片的选型至关重要。亿配芯城&#xff08;ICgoodFind…

2024软考网络工程师笔记 - 第8章.网络安全

文章目录 网络安全基础1️⃣网络安全威胁类型2️⃣网络攻击类型3️⃣安全目标与技术 &#x1f551;现代加密技术1️⃣私钥密码/对称密码体制2️⃣对称加密算法总结3️⃣公钥密码/非对称密码4️⃣混合密码5️⃣国产加密算法 - SM 系列6️⃣认证7️⃣基于公钥的认证 &#x1f552…

[Unity Demo]从零开始制作空洞骑士Hollow Knight第十五集:制作更多地图,更多敌人,更多可交互对象

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、第一个代表性场景 1.制作更多敌人2.制作更多可交互对象二、第二个代表性场景 1.制作更多敌人2.制作更多可交互对象三、第三个代表性场景 1.制作更多敌人2.制…

传感器驱动系列之PAW3212DB鼠标光电传感器

目录 一、PAW3212DB鼠标光电传感器简介 1.1 主要特点 1.2 引脚定义 1.3 传感器组装 1.4 应用场景 1.5 传感器使用注意 1.5.1 供电选择 1.5.2 SPI读写设置 1.5.3 MOTION引脚 1.6 寄存器说明 1.6.1 Product_ID1寄存器 1.6.2 MOTION_Status寄存器 1.6.3 Delta_X寄存器…