【.NET Core】Linq查询运算符(一)
【.NET Core】Linq查询运算符(一)
文章目录
- 【.NET Core】Linq查询运算符(一)
- 一、概述
- 二、筛选数据
- 三、投影运算
- 3.1 Select
- 3.2 SelectMany
- 3.3 Zip
- 3.4 Select 与 SelectMany
- 四、Set(设置)运算
- 4.1 Distinct或DistinctBy
- 4.2 Except或ExceptBy
- 4.3 Intersect或IntersectBy
- 4.4 Union或UnionBy
- 五、对数据进行排序
- 5.1 OrderBy
- 5.2 OrderByDescending
- 5.3 ThenBy
- 5.4 ThenByDescending
- 5.5 Reverse()
- 六、限定符运算
- 6.1 All
- 6.2 Any
- 6.2 Contains
- 七、数据分区
- 7.1 Skip
- 7.2 SkipWhile
- 7.3 Take
- 7.4 TakeWhile
- 7.5 Chunk
一、概述
查询运算符是组成Linq模式的方法。这些方法中的大多数都作用于序列;其中序列指其类型实现IEnumberable<T>
接口或IQueryable<T>
接口的对象。标准查询运算符提供包括筛选、投影、集合、排序等查询功能。
查询运算符包含两组,一组作用于类型IEnumberable<T>
的对象,另一组作用于类型IQueryable<T>
的对象。
二、筛选数据
筛选是指将结果集限制为仅包含满足指定条件的元素的操作。它也称为选定内容。筛选数据方法包含OfType和Where。
string[] list=["A","AB","BC","CD","DE","EF"];
IEnumerable<string> query = from chars in list where chars.Contains("B") select chars;
foreach(string ch in query){Console.WriteLine(str);
}
运行结果:
AB
BC
三、投影运算
投影是指将对象转换为一种新形式的操作,该形式通常只包含那些将随后使用的属性。通过使用投影,可以构造从每个对象生成的新类型。可以投影属性,并对属性执行数学函数。
3.1 Select
string[] list={"A","AB","BC","CD","DE","EF"};
IEnumerable<string> query = from chars in list select chars.ToLower();
foreach(string ch in query){Console.WriteLine(str)
}
运行结果
a
ab
bc
cd
de
ef
3.2 SelectMany
使用多个from子句来投影字符串列表中每个字符串的每个字符转变为大写。
string[] list = { "A|B|C|D","E|F|G|H"};
IEnumerable<string> query = from chars in list from ch in chars.Split('|')select ch;
foreach (string ch in query)
{Console.WriteLine(ch)
}
运行结果
A
B
C
D
E
F
G
H
3.3 Zip
Zip投影运算符有多个重载,所有Zip方法都处理两个或更多可能是异构类型的序列。前两个重载返回元组,具有来自给定序列的响应位置类型。
int[] index = { 1, 2, 3 };
string[] chars = { "A", "B", "C" };
IEnumerable<string> zip = chars.Zip(index, (n, w) => n + "=" + w);
foreach (var z in zip)
{Console.WriteLine(z);
}
运行结果
A=1
B=2
C=3
zip操作生成的序列的长度永远不会长于最短序列。index和letters集合的长度不同,生成的序列将省略index集合中的最后一个元素,因为它没有任何要压缩的内容。
3.4 Select 与 SelectMany
Select
与SelectMany
的工作都是依据源生成一个或多个结构值。Select
为每个源值生成一个结构值。因此,总体结构是一个与源集合具有相同元素数目的集合。 与之相反,SelectMany
生成单个总体结果,其中包含来自每个源值的串联子集合。 作为参数传递到 SelectMany
的转换函数必须为每个源值返回一个可枚举值序列。 然后,SelectMany
串联这些可枚举序列,以创建一个大的序列。
四、Set(设置)运算
LINQ 中的集运算是指根据相同或不同集合(或集)中是否存在等效元素来生成结果集的查询运算。
4.1 Distinct或DistinctBy
删除集合中的重复元素
int[] index = { 1, 2, 3 ,4};
string[] chars = { "A", "B", "C" , "B", "C" ,"D"};
IEnumerable<string> zip = from ch in chars.Distinct() select ch;
foreach (var z in zip)
{Console.WriteLine(z);
}
运行结果
A
B
C
D
在新.NET Framework中可以使用DistinctBy
替代Distinct
,DistinctBy
采用keySelector。keySelector
用作源类型的比较鉴别器。
4.2 Except或ExceptBy
Except返回的序列只包含位于第一个输入序列但不位于第二个输入序列的元素。
string[] listA = { "A", "B", "AC", "BC", "CD" };
string[] chars = { "A", "B", "C" , "B", "C" ,"D"};
IEnumerable<string> listC = from ch in chars.Except(listA) select ch;
foreach (var z in listC)
{Debug.WriteLine(z);
}
运行结果
C
D
ExceptBy
方法是 Except
的替代方法,它采用可能是异构类型的两个序列和一个 keySelector
。 keySelector
与第二个集合的类型相同,用作源类型的比较鉴别器。
4.3 Intersect或IntersectBy
返回序列包含两个输入序列共有的元素。
string[] listA = { "A", "B", "AC", "BC", "CD" };
string[] chars = { "A", "B", "C" , "B", "C" ,"D"};
IEnumerable<string> listC = from ch in chars.Intersect(listA) select ch;
foreach (var z in listC)
{Debug.WriteLine(z);
}
运行结果
A
B
IntersectBy
方法是Intersect
的替代方法,它采用可能是异构类型的两个序列和一个keySelector
。keySelector
用作第二个集合类型的比较鉴别器。
4.4 Union或UnionBy
两个字符串序列执行的联合操作。返回的序列包含两个输入序列的唯一元素。
string[] listA = { "A", "B", "AC", "BC", "CD" };
string[] chars = { "A", "B", "C" , "B", "C" ,"D"};
IEnumerable<string> listC = from ch in chars.Union(listA) select ch;
foreach (var z in listC)
{Debug.WriteLine(z);
}
运行结果
A
B
C
D
AC
BC
CD
五、对数据进行排序
排序操作基于一个或多个属性对序列的元素进行排序。 第一个排序条件对元素执行主要排序。 通过指定第二个排序条件,您可以对每个主要排序组内的元素进行排序。
5.1 OrderBy
结果集按升序对值排序。
string[] listA = { "A", "B", "AC", "BC", "CD" };
string[] chars = { "A", "B", "C" , "B", "C" ,"D"};
IEnumerable<string> listC = from ch in chars.Union(listA) orderby ch select ch;
foreach (var z in listC)
{Debug.WriteLine(z);
}
运行结果
A
AC
B
BC
C
CD
D
5.2 OrderByDescending
按降序对值排序。C#查询表达式语法orderby… descending
string[] listA = { "A", "B", "AC", "BC", "CD" };
string[] chars = { "A", "B", "C" , "B", "C" ,"D"};
IEnumerable<string> listC = from ch in chars.Union(listA) orderby ch descending select ch;
foreach (var z in listC)
{Debug.WriteLine(z);
}
运行结果
D
CD
C
BC
B
AC
A
5.3 ThenBy
按升序执行次要排序。orderby...
,...
string[] listA = { "A", "B", "AC", "BC", "CD" };
string[] chars = { "A", "B", "C" , "B", "C" ,"D"};
IEnumerable<string> listC = from ch in chars.Union(listA) orderby ch,ch.Length select ch;
foreach (var z in listC)
{Debug.WriteLine(z);
}
运行结果
A
AC
B
BC
C
CD
D
5.4 ThenByDescending
按降序执行次要顺序。C#查询表达式语法orderby…,… descending。
string[] listA = { "AB", "DC", "ED", "FH", "Z" };
IEnumerable<string> listC = from ch in listAorderby ch descending,ch.Length descendingselect ch;
foreach (var z in listC)
{Debug.WriteLine(z);
}
运行结果
Z
FH
ED
DC
AB
5.5 Reverse()
反转集合中元素的顺序
string[] listA = { "AB", "DC", "ED", "FH", "Z" };
IEnumerable<string> listC = listA.Reverse();
foreach (var z in listC)
{Debug.WriteLine(z);
}
运行结果
Z
FH
ED
DC
AB
六、限定符运算
限定符运算返回一个Boolean值,该值指示序列中是否有一些元素满足条件或是否所有元素都满足条件。
6.1 All
全部确定是否序列中的所有元素都满足条件
class Marketing
{public string Name{get;set;}public string[] Items{get;set;}
}
public static void Main(string[] args)
{List<Marketing> markets={new Market { Name = "Emily's", Items = {"kiwi", "cheery", "banana"} },new Market { Name = "Kim's", Items = {"melon", "mango", "olive"} },new Market { Name = "Adam's", Items = {"kiwi", "apple", "orange"} },} var names = from marker in marketswhere marker.Items.All(item=>item.Length == 5)select Name;foreach(string name in namse){Debug.WriteLine(name);}
}
6.2 Any
使用Any检查所有字符串是否以“o”开头。
class Market
{public string Name{get;set;}public string[] Items{get;set;}
}
public static void Main(string[] args)
{List<Market> markets={new Market { Name = "Emily's", Items = {"kiwi", "cheery", "banana"}},new Market { Name = "Kim's", Items = {"melon", "mango", "olive"} },new Market { Name = "Adam's", Items = {"kiwi", "apple", "orange"} }, }IEnumerable<string> names = from market in marketswhere market.Items.Any(item=>item.StartsWith("o"))select market.Name;foreach(string name in names){Debug.WriteLine(name);}
}
6.2 Contains
Contains检查所有数组是否具有特定元素。
class Market
{public string Name{get;set;}public string[] Items{get;set;}
}
public static void Main(string[] args)
{List<Market> markets={new Market { Name = "Emily's", Items = {"kiwi", "cheery", "banana"}},new Market { Name = "Kim's", Items = {"melon", "mango", "olive"} },new Market { Name = "Adam's", Items = {"kiwi", "apple", "orange"} }, }IEnumerable<string> names = from market in marketswhere market.Items.Contains("kiwi")select market.Name;foreach(string name in names){Debug.WriteLine(name);}
}
七、数据分区
Linq中的数据分区是指将输入序列划分为两个部分的操作,无需重新排列元素,然后返回其中一个部分。
7.1 Skip
Skip跳过序列中指定位置之前的元素。
string[] items ={"A", "B","C","D","E","F","G","H","I"};
var item= items.Skip(5);
foreach (var it in item)
{Console.WriteLine(it);
}
运行结果
F
G
H
I
7.2 SkipWhile
Skip指定跳过的数目,SkipWhile指定的跳过条件,而不是元素数。
string[] texts = new string[] { "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat" };
IEnumerable<string> skippedTexts = texts.SkipWhile(value => value.EndsWith("n"));
foreach (var it in skippedTexts)
{Console.WriteLine(it);
}
运行结果
Tue
Wed
Thu
Fri
Sat
7.3 Take
获取序列中指定位置之前的元素
string[] texts = new string[] { "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat" };
// 删除尾字母为n的
IEnumerable<string> skippedTexts = texts.Take(3);
foreach (var it in skippedTexts)
{Console.WriteLine(it);
}
运行结果
Sun
Mon
Tue
7.4 TakeWhile
TakeWhile
操作符用于从输入序列中返回指定数量且满足一定条件的元素。
当TakeWhile
操作符被调用时,会将source序列中的每一个元素顺序传递给委托predicate,只有哪些使用得predicate
返回值为true的元素才会被添加到结果序列中,要特别注意是,当TakeWhile
操作符在查找过程中,遇到第一个返回false的元素就会立即停止执行,跳出,无论后面还有没有符合条件的元素,即使后面有符合条件的元素也不会获取。对于第二个扩展方法,委托里面含有一个int类型的参数。
string[] lists = ["a", "e", "i", "o", "u"];
var takeList = lists.TakeWhile(x => x != "i");
foreach (var al in takeList)
{Console.WriteLine(al);
}
运行结果
a
e
7.5 Chunk
chunk 该方法将序列的元素拆分为指定大小的区块
string[] lists = {"公孙胜","鲁智深","林冲","吴用","李逵","宋江","武松" };
var nameList = lists.Chunk(3);
foreach (var names in nameList)
{foreach (var name in names) {Trace.WriteLine(name);}Trace.WriteLine("****************");
}
运行结果
公孙胜
鲁智深
林冲
****************
吴用
李逵
宋江
****************
武松
****************
相关文章:
【.NET Core】Linq查询运算符(一)
【.NET Core】Linq查询运算符(一) 文章目录 【.NET Core】Linq查询运算符(一)一、概述二、筛选数据三、投影运算3.1 Select 3.2 SelectMany3.3 Zip3.4 Select 与 SelectMany 四、Set(设置)运算4.1 Distinct…...

Python sorted函数及用法以及如何用json模块存储数据
Python sorted函数及用法 sorted() 函数与 reversed() 函数类似,该函数接收一个可迭代对象作为参数,返回一个对元素排序的列表。 在交互式解释器中测试该函数,可以看到如下运行过程: >>> a [20, 30, -1.2, 3.5, 90, 3.…...

使用opencv将sRGB格式的图片转换为BT.2020格式【sRGB】【BT.2020】
将sRGB格式的图片转换为BT.2020格式涉及到两个步骤:首先将sRGB转换到线性RGB,然后将线性RGB转换到BT.2020。这是因为sRGB图像通常使用伽马校正,而BT.2020工作在线性色彩空间中。 从sRGB到线性RGB:sRGB图像首先需要进行伽马校正解码…...
聊天注意事项
聊天成功的核心就是双方都能舒服 有些人不会聊天是缺乏引导性 聊天聊两句话就没了 聊天要把话题引导向对方 从倾诉者变为倾听者 才能不断交流 沟通不是一个人的独角戏 每个人都渴望被理解 要注意倾听别人说的话 不要只顾自己说一大堆,别人都瞌睡了 不要查户口式问…...

12.5 作业
1, 以下是一个简单的比喻,将多态概念与生活中的实际情况相联系: 比喻:动物园的讲解员和动物表演 想象一下你去了一家动物园,看到了许多不同种类的动物,如狮子、大象、猴子等。现在,动物园里有…...

深入理解指针3
hello,各位小伙伴,本篇文章跟大家一起继续深入学习指针,感谢大家对我上一篇的支持,如有什么问题,还请多多指教 如果本篇文章对你有帮助,还请各位点点赞!!! 话不多说&am…...
大数据环境下在线考试系统安全策略研究
摘 要 随着云计算、物联网、电子商务、企业信息化等的飞速发展,以及智能终端和各种检测、感应设备的普及和建设,全球逐渐进入信息化、网络化,由此产生了指数爆炸般的数据增长,一个大规模生产、分享和应用的数据的时代正在开启&am…...

Python中程序的异常处理
Python程序一般对输入有一定要求,担当实际输入不满足程序要求时,可能会产生程序的运行错误。Python语言使用的保留太容易try和except进行异常处理! try: 语句块1 except: 语句块2 语句块1是正常执行的程序内容,当这个语句块发生异…...

有趣的代码——有故事背景的程序设计3
这篇文章再和大家分享一些有“背景”的程序设计,希望能够让大家学到知识的同时,对编程学习更感兴趣,更能在这条路上坚定地走下去。 目录 1.幻方问题 2.用函数打印九九乘法表 3.鸡兔同笼问题 4.字数统计 5.简单选择排序 1.幻方问题 幻方又…...

聚观早报 |国行PS5轻薄版开售;岚图汽车11月交付7006辆
【聚观365】12月2日消息 国行PS5轻薄版开售 岚图汽车11月交付7006辆 比亚迪推出12月限时优惠 特斯拉正式交付首批Cybertruck 昆仑万维发布「天工 SkyAgents」平台 国行PS5轻薄版开售 索尼最新的PlayStation5主机(CFI-2000型号组-轻薄版)国行版本正…...

Kafka 保证消息消费全局顺序性
当有消息被生产出来的时候,如果没有指定分区或者指定 key ,那么消费会按照【轮询】的方式均匀地分配到所有可用分区中,但不一定按照分区顺序来分配 我们知道,在 Kafka 中消费者可以订阅一个或多个主题,并被分配一个或多…...
3分钟在CentOS 7上离线安装Docker
在CentOS 7上离线安装Docker的详细步骤如下: 环境检查和准备 检查内核版本:Docker要求系统为64位且内核版本至少为3.10。使用命令uname -r查看内核版本。 检查CentOS版本:通过命令cat /etc/redhat-release查看版本信息。 更新yum包࿰…...

GaussDB数据库SQL系列-触发器
目录 一、前言 二、触发器概念 三、GaussDB数据库中的触发器 1、语法格式 2、创建步骤 3、注意事项 4、附:表和视图上支持的触发器种类 四、GaussDB数据库中的示例 示例一、在GaussDB数据库中创建一个触发器,以便在插入新记录时自动将记录的创建…...

网工学习10-IP地址
一、IP地址概念 IP地址是一个32位的二进制数,它由网络ID和主机ID两部份组成,用来在网络中唯一的标识的一台计算机。网络ID用来标识计算机所处的网段;主机ID用来标识计算机在网段中的位置。IP地址通常用4组3位十进制数表示,中间用…...

二百零八、Hive——HiveSQL异常:Select查询数据正常,但SQL语句加上group by查询数据为空
一、目的 在HiveSQL的DWD层中,需要对原始数据进行去重在内的清洗,结果一开始其他数据类型的清洗工作都正常,直到碰到转向比数据。 一般的SQL查询有数据,但是加上group by以后就没数据; 一般的SQL查询有数据…...

Docker—共享应用程序
现在您已经构建了一个映像,可以共享它。要共享Docker映像,您必须使用Docker注册表。默认注册表是Docker Hub,是您使用的所有图像的来源。 Docker ID(Docker标识) Docker ID允许您访问Docker Hub,这是世界上…...

Linux横向移动
Linux横向移动 主机存活探测 shell for i in 192.168.111.{1..254}; do if ping -c 3 -w 3 $i &>/dev/null; then echo $i is alived; fi; done 或者 for k in $( seq 1 255);do ping -c 1 192.168.1.$k|grep "ttl"|awk -F "[ :]" {print $4}; d…...

Ubuntu 20.0 + mysql 8.0 用户和密码修改
第一步 下载(简单,注意联网)Ubuntu 终端输入以下两行命令 (1) 数据库的服务端及客户端数据库的开发软件包 sudo apt-get install mysql-server mysql-client (2) 数据库的开发软件包 sudo apt-get install libmysqlclient-dev 第二步 查看是否安装成功 …...

看懂lscpu的输出
文章目录 1. lscpu1.1 Architecture1.2 逻辑核心数1.3 缓存1.4 CPU型号1.5 NUMA架构1.5.1 CPU多核架构1.5.2 多CPU Socket架构 2. cat /proc/cpuinfo2.1 关键字段 1. lscpu 通过lscpu查看当前系统的CPU信息。 [hadoopserver3 ~]$ lscpuArchitecture: x86_64 …...

RoPE旋转位置编码浅析
RoPE旋转位置编码浅析 本文介绍了旋转位置编码RoPE在大模型中的广泛应用,包括Llama、Mistral 7B、Baichuan、ChatGLM、Qwen、…等。由于计算资源限制,大模型通常在较小的上下文长度中进行训练,导致在推理超出预训练长度时性能显著下降。为了解决这个问题,涌现了许多基于Ro…...

Mybatis逆向工程,动态创建实体类、条件扩展类、Mapper接口、Mapper.xml映射文件
今天呢,博主的学习进度也是步入了Java Mybatis 框架,目前正在逐步杨帆旗航。 那么接下来就给大家出一期有关 Mybatis 逆向工程的教学,希望能对大家有所帮助,也特别欢迎大家指点不足之处,小生很乐意接受正确的建议&…...

Linux相关概念和易错知识点(42)(TCP的连接管理、可靠性、面临复杂网络的处理)
目录 1.TCP的连接管理机制(1)三次握手①握手过程②对握手过程的理解 (2)四次挥手(3)握手和挥手的触发(4)状态切换①挥手过程中状态的切换②握手过程中状态的切换 2.TCP的可靠性&…...
关于 WASM:1. WASM 基础原理
一、WASM 简介 1.1 WebAssembly 是什么? WebAssembly(WASM) 是一种能在现代浏览器中高效运行的二进制指令格式,它不是传统的编程语言,而是一种 低级字节码格式,可由高级语言(如 C、C、Rust&am…...

IT供电系统绝缘监测及故障定位解决方案
随着新能源的快速发展,光伏电站、储能系统及充电设备已广泛应用于现代能源网络。在光伏领域,IT供电系统凭借其持续供电性好、安全性高等优势成为光伏首选,但在长期运行中,例如老化、潮湿、隐裂、机械损伤等问题会影响光伏板绝缘层…...
Web 架构之 CDN 加速原理与落地实践
文章目录 一、思维导图二、正文内容(一)CDN 基础概念1. 定义2. 组成部分 (二)CDN 加速原理1. 请求路由2. 内容缓存3. 内容更新 (三)CDN 落地实践1. 选择 CDN 服务商2. 配置 CDN3. 集成到 Web 架构 …...

【从零学习JVM|第三篇】类的生命周期(高频面试题)
前言: 在Java编程中,类的生命周期是指类从被加载到内存中开始,到被卸载出内存为止的整个过程。了解类的生命周期对于理解Java程序的运行机制以及性能优化非常重要。本文会深入探寻类的生命周期,让读者对此有深刻印象。 目录 …...

解读《网络安全法》最新修订,把握网络安全新趋势
《网络安全法》自2017年施行以来,在维护网络空间安全方面发挥了重要作用。但随着网络环境的日益复杂,网络攻击、数据泄露等事件频发,现行法律已难以完全适应新的风险挑战。 2025年3月28日,国家网信办会同相关部门起草了《网络安全…...
十九、【用户管理与权限 - 篇一】后端基础:用户列表与角色模型的初步构建
【用户管理与权限 - 篇一】后端基础:用户列表与角色模型的初步构建 前言准备工作第一部分:回顾 Django 内置的 `User` 模型第二部分:设计并创建 `Role` 和 `UserProfile` 模型第三部分:创建 Serializers第四部分:创建 ViewSets第五部分:注册 API 路由第六部分:后端初步测…...
全面解析数据库:从基础概念到前沿应用
在数字化时代,数据已成为企业和社会发展的核心资产,而数据库作为存储、管理和处理数据的关键工具,在各个领域发挥着举足轻重的作用。从电商平台的商品信息管理,到社交网络的用户数据存储,再到金融行业的交易记录处理&a…...
DiscuzX3.5发帖json api
参考文章:PHP实现独立Discuz站外发帖(直连操作数据库)_discuz 发帖api-CSDN博客 简单改造了一下,适配我自己的需求 有一个站点存在多个采集站,我想通过主站拿标题,采集站拿内容 使用到的sql如下 CREATE TABLE pre_forum_post_…...