[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

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

常用的jdk下载地址

jdk下载地址 安装方式可以看之前的博客: mac安装jdk oracle 版本:https://www.oracle.com/java/technologies/downloads/ Eclipse Temurin版本:https://adoptium.net/zh-CN/temurin/releases/ 阿里版本: github:https://github.com/

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

30常用 Maven 命令

Maven 是一个强大的项目管理和构建工具,它广泛用于 Java 项目的依赖管理、构建流程和插件集成。Maven 的命令行工具提供了大量的命令来帮助开发人员管理项目的生命周期、依赖和插件。以下是 常用 Maven 命令的使用场景及其详细解释。 1. mvn clean 使用场景:清理项目的生成目录,通常用于删除项目中自动生成的文件(如 target/ 目录)。共性规律:清理操作

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M

019、JOptionPane类的常用静态方法详解

目录 JOptionPane类的常用静态方法详解 1. showInputDialog()方法 1.1基本用法 1.2带有默认值的输入框 1.3带有选项的输入对话框 1.4自定义图标的输入对话框 2. showConfirmDialog()方法 2.1基本用法 2.2自定义按钮和图标 2.3带有自定义组件的确认对话框 3. showMessageDialog()方法 3.1

工作常用指令与快捷键

Git提交代码 git fetch  git add .  git commit -m “desc”  git pull  git push Git查看当前分支 git symbolic-ref --short -q HEAD Git创建新的分支并切换 git checkout -b XXXXXXXXXXXXXX git push origin XXXXXXXXXXXXXX