C# LINQ 基础与应用

前言

Language Integrated Query 中文名称为语言集成查询,其简称 LINQ,是将查询功能集成到编程语言中的技术。通过LINQ,我们可以用SQL查询数据的方式来从数据源检索数据,如集合、XML、数组、数据库等。LINQ使得编写代码更简洁与直观,提高了代码的可读性和可维护。

基础

LINQ查询由获取数据源、创建查询、执行查询三个不同操作组成,对应的每个组成部分都有相应的语法或者要求。from 子句指定数据源,**where 子句应用筛选器,**select 子句指定返回的元素的类型。

数据源

数据源通常都是支持 IEnumerable或派生接口(如 IQueryable)的类型,这些类型称为可查询类型。对于非可查询类型,LINQ提供了一些对应的程序。如LINQ to XML、LINQ to Object、LINQ to Entities等。

// 数据源--整型数组
int[] numbers = new int[] {20,50,100,15,85,10,30,70};
// 创建查询 numberQueryInfo是一个IEnumerable<int>
var numberQueryInfo = from number in numbers select number;

使用LINQ to XML

string xmlPath =string.Format("{0}{1}", AppDomain.CurrentDomain.BaseDirectory, "version.xml");
// 数据源--XML文档
XElement contacts = XElement.Load(xmlPath);
查询

查询指定从数据源中检索的信息,对查询返回信息进行排序、分组、结构化后存储在查询变量中。C#可以使用查询语法或方法语法来编写查询。

1、查询语法
1.1 基本查询操作

通过from指定数据源,使用where进行过滤筛选,以select 子句指定返回的元素的类型。

using System;
using System.Collections.Generic;
using System.Linq;namespace Fountain.WinConsole.LinqDemo
{internal class Program{static void Main(string[] args){PaymentMethod payment1 = new PaymentMethod(){MethodId = 1,MethodName = "现金"};PaymentMethod payment2 = new PaymentMethod(){MethodId = 2,MethodName = "网银"};PaymentMethod payment3 = new PaymentMethod(){MethodId = 3,MethodName = "支付宝"};PaymentMethod payment4 = new PaymentMethod(){MethodId = 4,MethodName = "微信"};List<PaymentMethod> payments = new List<PaymentMethod>(){ payment1,payment2,payment3, payment4 };// 查询所有付款方式大于2方式var paymentQuery = from nPayment in payments where nPayment.MethodId > 2orderby nPayment.MethodId descendingselect nPayment;}}
}
1.2 查询结果排序

使用orderby对查询结果进行排序,用ascending表示升序,descending表示降序。

using System;
using System.Collections.Generic;
using System.Linq;namespace Fountain.WinConsole.LinqDemo
{internal class Program{static void Main(string[] args){PaymentMethod payment1 = new PaymentMethod(){MethodId = 1,MethodName = "现金"};PaymentMethod payment2 = new PaymentMethod(){MethodId = 2,MethodName = "网银"};PaymentMethod payment3 = new PaymentMethod(){MethodId = 3,MethodName = "支付宝"};PaymentMethod payment4 = new PaymentMethod(){MethodId = 4,MethodName = "微信"};List<PaymentMethod> payments = new List<PaymentMethod>(){ payment1,payment2,payment3, payment4 };// 查询所有付款方式大于2方式var paymentQuery = from nPayment in payments where nPayment.MethodId > 2orderby nPayment.MethodId descendingselect nPayment;// 输出结果foreach (PaymentMethod paymentItem in paymentQuery) { Console.WriteLine(string.Format("方式{0}-名称:{1}",paymentItem.MethodId,paymentItem.MethodName)); }}}
}   
1.3 查询结果分组

使用group对查询结果进行分组,以by来指定分组的条件。

using System;
using System.Collections.Generic;
using System.Linq;namespace Fountain.WinConsole.LinqDem

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【数据结构初阶】二叉树---堆

二叉树-堆的实现 一、树的概念&#xff08;什么是树&#xff09;二、二叉树的概念及结构2.1 二叉树的概念2.2 二叉树的性质2.3 二叉树存储结构 三、二叉树的顺序结构3.1 堆的概念及结构3.2 堆的向下调整算法3.3堆的创建 四、堆的代码实现4.1 堆的初始化4.2 堆的销毁4.3 堆的插入…

ipguard与Ping32如何加密数据防止泄露?让企业信息更安全

在信息化时代&#xff0c;数据安全已成为企业运营的重中之重。数据泄露不仅会导致经济损失&#xff0c;还可能损害企业声誉。因此&#xff0c;选择合适的数据加密工具是保护企业敏感信息的关键。本文将对IPGuard与Ping32这两款加密软件进行探讨&#xff0c;了解它们如何有效加密…

SAP_SD模块-销售订单创建价格扩大10倍问题分析及后续订单价格批量更新问题处理

一、业务背景 我们公司的销售订单&#xff0c;是通过第三方销售管理平台创建好订单后&#xff0c;把表头和行项目数据&#xff0c;定时推送到SAP&#xff1b;SAP通过自定义表ZZT_ORDER_HEAD存放订单表头数据&#xff0c;通过ZZT_ORDER_DETAIL存放行项目数据&#xff1b;然后再用…

git安装-Tortoise git 安装汉化教程

1. 安装git 2. 安装git图形化工具Tortoise git 3. 汉化 Tortoise git 汉化安装包

证件照电子版怎么弄?不花钱制作方法快来学

想要制作免费照证件照&#xff1f;证件照在我们的日常生活中扮演着重要角色&#xff0c;无论是求职、求学还是办理各类证件&#xff0c;都少不了它的身影。 但是&#xff0c;去照相馆拍照不仅耗时&#xff0c;费用也不菲。那么&#xff0c;有没有可能不花一分钱就搞定证件照呢…

互联网系统的微观与宏观架构

互联网系统的架构设计&#xff0c;通常会根据项目的体量、业务场景以及技术需求被划分为微观架构&#xff08;Micro-Architecture&#xff09;和宏观架构&#xff08;Macro-Architecture&#xff09;。这两者的概念与职责既独立又相互关联。本文将通过一些系统案例&#xff0c;…

淘宝API的实战应用:数据驱动增长,实时监控商品信息是关键

数据驱动增长&#xff0c;实时监控商品信息是关键 —— 淘宝API的实战应用 在数字化时代&#xff0c;数据已经成为商业决策的核心。对于电商行业而言&#xff0c;获取准确、实时的数据是保持竞争力的关键。淘宝API接口作为连接淘宝电商平台与外部应用的桥梁&#xff0c;为电商商…

【论文+源码】基于spring boot的垃圾分类网站

创建一个基于Spring Boot的垃圾分类网站涉及多个步骤&#xff0c;包括环境搭建、项目创建、数据库设计、后端服务开发、前端页面设计等。下面我将引导您完成这个过程。 第一步&#xff1a;准备环境 确保您的开发环境中安装了以下工具&#xff1a; Java JDK 8 或更高版本Mav…

uv: 一个统一的Python包管理工具

uv是由Astral公司开发的一个极其快速的Python包管理器,完全用Rust编写。它最初在2月份发布,作为pip工作流的替代品。现在,uv已经扩展成为一个端到端的解决方案,可以管理Python项目、命令行工具、单文件脚本,甚至Python本身。可以说,uv就像是Python界的Cargo:一个快速、可靠、易…

Rust小练习,编写井字棋

画叉画圈的游戏通常指的是 井字棋&#xff08;Tic-Tac-Toe&#xff09;&#xff0c;是一个简单的两人游戏&#xff0c;规则如下&#xff1a; 游戏规则 棋盘&#xff1a;游戏在一个3x3的方格上进行。玩家&#xff1a;有两个玩家&#xff0c;一个用“X”表示&#xff0c;另一个…

Vivado自定义IP修改顶层后Port and Interface不更新解决方案

问题描述 在整个项目工程中&#xff0c;对自定义IP进行一个比较大的改动&#xff0c;新增了不少端口(这里具体的就是bram的读写端口)&#xff0c;修改是在block design中右击IP编辑在IP编辑工程中进行的。 在修改完所有代码后&#xff08;顶层新增了需要新加的输入输出端口&…

算法的学习笔记—平衡二叉树(牛客JZ79)

&#x1f600;前言 在数据结构中&#xff0c;二叉树是一种重要的树形结构。平衡二叉树是一种特殊的二叉树&#xff0c;其特性是任何节点的左右子树高度差的绝对值不超过1。本文将介绍如何判断一棵给定的二叉树是否为平衡二叉树&#xff0c;重点关注算法的时间复杂度和空间复杂度…

未来汽车驾驶还会有趣吗?车辆动力学系统简史

未来汽车驾驶还会有趣吗&#xff1f;车辆动力学系统简史 本篇文章来源&#xff1a;Schmidt, F., Knig, L. (2020). Will driving still be fun in the future? Vehicle dynamics systems through the ages. In: Pfeffer, P. (eds) 10th International Munich Chassis Symposiu…

sql-labs靶场第二十关测试报告

目录 一、测试环境 1、系统环境 2、使用工具/软件 二、测试目的 三、操作过程 1、寻找注入点 2、注入数据库 ①寻找注入方法 ②爆库&#xff0c;查看数据库名称 ③爆表&#xff0c;查看security库的所有表 ④爆列&#xff0c;查看users表的所有列 ⑤成功获取用户名…

文本预处理——构建词云

Python 词云或标签云是一种可视化技术&#xff0c;通常用于显示网站的标签或关键字。这些单个单词反映了网页的上下文&#xff0c;并聚集在词云中。云中的单词字体大小和颜色各不相同&#xff0c;表明其突出性。字体大小越大&#xff0c;相对于其他单词的重要性就越高。词云可以…

VUE中文本域默认展示最底部内容

文本域内容 <textarea ref"textareaRef" style"width: 100%; resize: none;" readonly v-model"errorLog" rows"15"></textarea> 样式展示 this.$nextTick(() > { // 使用$refs获取文本域的DOM元素 const textareaInfo…

【ArcGIS Pro实操第8期】绘制WRF三层嵌套区域

【ArcGIS Pro实操第8期】绘制WRF三层嵌套区域 数据准备ArcGIS Pro绘制WRF三层嵌套区域Map-绘制三层嵌套区域更改ArcMap地图的默认显示方向指定数据框范围 Map绘制研究区Layout-布局出图 参考 本博客基于ArcGIS Pro绘制WRF三层嵌套区域&#xff0c;具体实现图形参考下图&#xf…

C++游戏开发教程:从入门到进阶

C游戏开发教程&#xff1a;从入门到进阶 前言 在游戏开发的世界里&#xff0c;C以其高效的性能和灵活的特性&#xff0c;成为了众多游戏开发者的首选语言。在本教程中&#xff0c;我们将带您从基础知识入手&#xff0c;逐步深入到实际的游戏开发项目中。无论您是初学者还是有…

算法的学习笔记—数组中只出现一次的数字(牛客JZ56)

&#x1f600;前言 在数组中寻找只出现一次的两个数字是一道经典的问题&#xff0c;通常可以通过位运算来有效解决。本文将详细介绍这一问题的解法&#xff0c;深入解析其背后的思路。 &#x1f3e0;个人主页&#xff1a;尘觉主页 文章目录 &#x1f970;数组中只出现一次的数字…

基于Netty构建WebSocket服务并实现项目群组聊天和实时消息通知推送

文章目录 前言需求分析技术预研Web端方案服务端技术 技术方案设计思路功能实现添加依赖自定义NettyServer自定义webSocketHandler使用NettyServer向在线用户发送消息 需要完善的地方 前言 我们的项目有个基于项目的在线文档编制模块&#xff0c;可以邀请多人项目组成员在线协同…