[C#] Linq常用语法

2024-05-26 07:08
文章标签 c# 语法 常用 .net netcore linq

本文主要是介绍[C#] Linq常用语法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

<strong>Linq常用语法</strong>

 Student[] student = {            new Student{ID=1, Name="小黑",Age=3,Class=1},new Student{ID=2,Name="小布",Age=5,Class=1},new Student{ID=3,Name="朱迪",Age=20,Class=2},new Student{ID=4,Name="狐尼克",Age=21,Class=2}};
StudentClass[] studentClass = { new StudentClass{ID=1, Name="一班"},new StudentClass{ID=2, Name="二班"}};

1 简单的linq语法

 //1 简单的linq语法var s11 = from r in studentselect r;var s12 = student;//"select * from student";

2.linq where 查询

  var s21 = from r in studentwhere r.ID > 2select r;var s22 = student.Where(p => p.ID > 2);//"select * from student where ID>2";

3.linq 简单的函数计算(count,min,max,sum)

           //获取最大的IDvar s311 = (from r in studentselect r).Max(p => p.ID);//获取最小的IDvar s312 = (from r in studentselect r).Min(p => p.ID);//获取结果集的总数var s313 = (from r in studentselect r).Count();//获取ID的和var s314 = (from r in studentselect r).Sum(p => p.ID);var s321 = student.Max(p => p.ID);var s322 = student.Min(p => p.ID);var s323 = student.Count();var s324 = student.Sum(p => p.ID);// "select max(ID) from student";// "select min(ID) from studente";// "select count(1) from student";// "select sum(ID) from student";

4.linq 排序order by desc/asc

            var s41 = from r in studentwhere r.ID > 1orderby r.ID descending  //倒序//orderby r.ID ascending   //正序select r;//正序var s42 = student.OrderBy(p => p.ID).Where(p => p.ID > 1).ToList();//倒序var s43 = student.OrderByDescending(p => p.ID).Where(p => p.ID > 1).ToList();// "select * from student where ID>1 order by ID [desc|asc]";

5.linq top

 //如果取最后一个可以按倒叙排列再取值var s51 = (from r in student                     select r).FirstOrDefault();//()linq to ef 好像不支持 Last() var s52 = student.FirstOrDefault();var s53 = student.First();// "select top(1) * from student";

6.linq 跳过前面多少条数据取余下的数据

var s61 = (from r in studentorderby r.ID descendingselect r).Skip(10); //跳过前10条数据,取10条之后的所有数据   var s62 = student.OrderByDescending(p => p.ID).Skip(10).ToList();
// "select * from  (select ROW_NUMBER()over(order by ID desc) as rowNum, * from [student]) as t where rowNum>10";

7.linq 分页数据查询

 var s71 = (from r in studentwhere r.ID > 10orderby r.ID descendingselect r).Skip(10).Take(10); //取第11条到第20条数据                   //Take(10): 数据从开始获取,获取指定数量(10)的连续数据var s72 = student.OrderByDescending(p => p.ID).Where(p => p.ID > 10).Skip(10).Take(10).ToList();//"select * from  (select ROW_NUMBER()over(order by ID desc) as rowNum, * from [student]) as t // where rowNum>10 and rowNum<=20";

8.linq 包含,类似like '%%'

 var s81 = from r in studentwhere r.Name.Contains("小")select r;var s82 = student.Where(p => p.Name.Contains("小")).ToList();// "select * from student where Name like '%小%'";

9.linq 分组group by

 var s91 = from r in studentorderby r.ID descendinggroup r by r.Class into nselect new{n.Key,  //这个Key是recTyperpId = n.Sum(r => r.ID), //组内rpId之和MaxRpId = n.Max(r => r.ID),//组内最大rpIdMinRpId = n.Min(r => r.ID), //组内最小rpId};foreach (var t in s91){Console.Write(t.Key + "--" + t.rpId + "--" + t.MaxRpId + "--" + t.MinRpId);}//2var s92 = from r in studentorderby r.ID descendinggroup r by r.Class into nselect n;foreach (var t in s92){Console.Write(t.Key + "--" + t.Min(p => p.ID));}//3var s93 = student.GroupBy(p => p.Class);foreach (var t in s93){Console.Write(t.Key + "--" + t.Min(p => p.ID));}//"select Class,min(ID),max(ID),sum(ID) from student group by Class";

10.linq 连接查询 

  //1var s101 = from r in studentjoin w in studentClass on r.Class equals w.IDorderby r.ID descendingselect r;//2
var s102 = student.Join(studentClass, p => p.Class, r => r.ID, (p, r) => p).OrderByDescending(p => p.ID).ToList();//3// "select r.* from  student as r //               inner join [dbo].[studentClass] as t //                           on r.[Class] = t.[ID] //order by r.[ID] desc";

11.linq 中的In

  var s111 = from p in studentwhere (new int?[] { 2,3,4 }).Contains(p.ID)select p;foreach (var p in s111){Console.Write(p.Name);}//2//"select * from student where ID in(2,3,4)";


参考原文:http://www.cnblogs.com/knowledgesea/p/3897665.html
 

这篇关于[C#] Linq常用语法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1003777

相关文章

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

C#下Newtonsoft.Json的具体使用

《C#下Newtonsoft.Json的具体使用》Newtonsoft.Json是一个非常流行的C#JSON序列化和反序列化库,它可以方便地将C#对象转换为JSON格式,或者将JSON数据解析为C#对... 目录安装 Newtonsoft.json基本用法1. 序列化 C# 对象为 JSON2. 反序列化

C#文件复制异常:"未能找到文件"的解决方案与预防措施

《C#文件复制异常:未能找到文件的解决方案与预防措施》在C#开发中,文件操作是基础中的基础,但有时最基础的File.Copy()方法也会抛出令人困惑的异常,当targetFilePath设置为D:2... 目录一个看似简单的文件操作问题问题重现与错误分析错误代码示例错误信息根本原因分析全面解决方案1. 确保

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

C#高效实现Word文档内容查找与替换的6种方法

《C#高效实现Word文档内容查找与替换的6种方法》在日常文档处理工作中,尤其是面对大型Word文档时,手动查找、替换文本往往既耗时又容易出错,本文整理了C#查找与替换Word内容的6种方法,大家可以... 目录环境准备方法一:查找文本并替换为新文本方法二:使用正则表达式查找并替换文本方法三:将文本替换为图