这篇文章主要讲解了“LINQ表达式指定目标数据的方法有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“LINQ表达式指定目标数据的方法有哪些”吧!
创新互联公司专注于萧山企业网站建设,成都响应式网站建设公司,商城网站定制开发。萧山网站建设公司,为萧山等地区提供建站服务。全流程按需网站设计,专业设计,全程项目跟踪,创新互联公司专业和态度为您提供的服务
LINQ表达式是实现LINQ功能的重要部分,一般是通过相关关键字来实现查询、修改、删除等功能。这些关键字,一般和数据库控制的关键字近似,比如from、select、where等等。
1.LINQ表达式关键字
关键字功能
from 指定要查找的数据源以及范围变量,多个from子句则表示从多个数据源查找数据
select 指定查询要返回的目标数据,可以指定任何类型,甚至是匿名类型
where 指定元素的筛选条件,多个where子句则表示了并列条件,必须全部都满足才能入选
orderby 指定元素的排序字段和排序方式。当有多个排序字段时,由字段顺序确定主次关系,可指定升序和降序两种排序方式
group指定元素的分组字段
join 指定多个数据源的关联方式
2.LINQ表达式用from子句指定数据源
每个LINQ查询都以from子句开始,from子句包括以下两个功能。
指定查询将采用数据源。
定义一个本地变量,表示数据源中单个元素。
单个from子句的编写格式如下所示。其中dataSource表示数据源,localVar表示单个元素。
from localVar in dataSource
3.LINQ表达式用select子句指定目标数据
select子句指定在执行查询时产生结果的数据集中元素的类型,它的格式如下所示:
select element
4.LINQ表达式用where子句指定筛选条件
在LINQ中,用where子句指定查询的过滤条件,它的格式如下:
where expr ession 其中,express是一个逻辑表达式,返回布尔值“真”或“假”,在LINQ查询中,还可以使用多个并列的where子句来进行多个条件过滤。数据源中的元素只有同时满足所有where子句的条件才能作为查询结果。
5.LINQ表达式用orderby子句进行排序
在LINQ中,通过orderby子句对查询结果进行排序操作,它的格式如下:
orderby element [sortType] 其中,element是要进行排序的字段,它可以是数据源中的元素,也可以是对元素的操作结果。sortType是可选参数,表示排序类型,包括升序(ascending)和降序(desending)两个可选值,默认情况下为ascending。
LINQ表达式需注意:
orderby子句和where子句不一样,当在一个LINQ查询中出现多个orderby子句时,只有***一个orderby子句有效,前面的orderby子句都无效。
6.LINQ表达式用group子句进行分组
在LINQ中,用group子句实现对查询结果的分组操作。在LINQ中,group子句的常用格式如下:
group element by key 其中,element表示作为查询结果返回的元素,key表示分组条件,。group子句返回类型为IGrouping的查询结果。其中,TKey的类型为参数key的数据类型,TElement的类型是参数element的数据类型。
有时需要对分组的结果进行排序,再次查询等操作。这就需要使用into关键字将group查询的结果保存到一个临时变量,并且必须使用新的select或group子句对其进行重新查询,也可以使用orderby进行排序、用where进行过滤等操作。into关键字的语法格式如下:
group element by key into tmpGrp 其中tmpGrp表示一个本地变量,用来临时保存group产生的结果,提供后面的LINQ表达式子句使用。
感谢各位的阅读,以上就是“LINQ表达式指定目标数据的方法有哪些”的内容了,经过本文的学习后,相信大家对LINQ表达式指定目标数据的方法有哪些这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!
分享名称:LINQ表达式指定目标数据的方法有哪些
文章起源:https://www.cdcxhl.com/article24/jicsce.html
成都网站建设公司_创新互联,为您提供手机网站建设、云服务器、搜索引擎优化、Google、电子商务、虚拟主机
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联