[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++库

《C#如何调用C++库》:本文主要介绍C#如何调用C++库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录方法一:使用P/Invoke1. 导出C++函数2. 定义P/Invoke签名3. 调用C++函数方法二:使用C++/CLI作为桥接1. 创建C++/CL

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式

Python的time模块一些常用功能(各种与时间相关的函数)

《Python的time模块一些常用功能(各种与时间相关的函数)》Python的time模块提供了各种与时间相关的函数,包括获取当前时间、处理时间间隔、执行时间测量等,:本文主要介绍Python的... 目录1. 获取当前时间2. 时间格式化3. 延时执行4. 时间戳运算5. 计算代码执行时间6. 转换为指

Python正则表达式语法及re模块中的常用函数详解

《Python正则表达式语法及re模块中的常用函数详解》这篇文章主要给大家介绍了关于Python正则表达式语法及re模块中常用函数的相关资料,正则表达式是一种强大的字符串处理工具,可以用于匹配、切分、... 目录概念、作用和步骤语法re模块中的常用函数总结 概念、作用和步骤概念: 本身也是一个字符串,其中

usb接口驱动异常问题常用解决方案

《usb接口驱动异常问题常用解决方案》当遇到USB接口驱动异常时,可以通过多种方法来解决,其中主要就包括重装USB控制器、禁用USB选择性暂停设置、更新或安装新的主板驱动等... usb接口驱动异常怎么办,USB接口驱动异常是常见问题,通常由驱动损坏、系统更新冲突、硬件故障或电源管理设置导致。以下是常用解决

Mysql用户授权(GRANT)语法及示例解读

《Mysql用户授权(GRANT)语法及示例解读》:本文主要介绍Mysql用户授权(GRANT)语法及示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql用户授权(GRANT)语法授予用户权限语法GRANT语句中的<权限类型>的使用WITH GRANT

C# foreach 循环中获取索引的实现方式

《C#foreach循环中获取索引的实现方式》:本文主要介绍C#foreach循环中获取索引的实现方式,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、手动维护索引变量二、LINQ Select + 元组解构三、扩展方法封装索引四、使用 for 循环替代

C# Where 泛型约束的实现

《C#Where泛型约束的实现》本文主要介绍了C#Where泛型约束的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录使用的对象约束分类where T : structwhere T : classwhere T : ne

HTML5表格语法格式详解

《HTML5表格语法格式详解》在HTML语法中,表格主要通过table、tr和td3个标签构成,本文通过实例代码讲解HTML5表格语法格式,感兴趣的朋友一起看看吧... 目录一、表格1.表格语法格式2.表格属性 3.例子二、不规则表格1.跨行2.跨列3.例子一、表格在html语法中,表格主要通过< tab