深入浅出 LINQ表达式

开发 后端
LINQ表达式是实现LINQ功能的重要部分,一般是通过相关关键字来实现查询、修改、删除等功能。这些关键字,一般和数据库控制的关键字近似,比如from、select、where等等。

本文从六个方面对LINQ表达式做简单介绍,它们其中有LINQ表达式关键字、LINQ表达式用from子句指定数据源、LINQ表达式用select子句指定目标数据等等。

LINQ表达式是实现LINQ功能的重要部分,一般是通过相关关键字来实现查询、修改、删除等功能。这些关键字,一般和数据库控制的关键字近似,比如from、select、where等等。

1.LINQ表达式关键字

关键字功能

from 指定要查找的数据源以及范围变量,多个from子句则表示从多个数据源查找数据

select 指定查询要返回的目标数据,可以指定任何类型,甚至是匿名类型

where 指定元素的筛选条件,多个where子句则表示了并列条件,必须全部都满足才能入选

orderby 指定元素的排序字段和排序方式。当有多个排序字段时,由字段顺序确定主次关系,可指定升序和降序两种排序方式

group指定元素的分组字段

join 指定多个数据源的关联方式

2.LINQ表达式用from子句指定数据源

每个LINQ查询都以from子句开始,from子句包括以下两个功能。

指定查询将采用数据源。

定义一个本地变量,表示数据源中单个元素。

单个from子句的编写格式如下所示。其中dataSource表示数据源,localVar表示单个元素。

  1. from localVar in dataSource  

3.LINQ表达式用select子句指定目标数据

select子句指定在执行查询时产生结果的数据集中元素的类型,它的格式如下所示:

  1. 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表达式子句使用。

【编辑推荐】

  1. 详谈Linq查询结果分析的方法
  2. 简简单单学习Linq查询语法
  3. 详细阐述Linq插入数据的操作方法
  4. 浅析Linq插入数据的实现方法
  5. 简单解决Linq多条件组合问题
责任编辑:阡陌 来源: 狂人工作室
相关推荐

2009-09-17 14:21:19

LINQ表达式

2009-09-07 17:18:33

LINQ查询表达式

2021-03-16 08:54:35

AQSAbstractQueJava

2011-07-04 10:39:57

Web

2019-01-07 15:29:07

HadoopYarn架构调度器

2017-07-02 18:04:53

块加密算法AES算法

2021-07-20 15:20:02

FlatBuffers阿里云Java

2012-05-21 10:06:26

FrameworkCocoa

2022-09-26 09:01:15

语言数据JavaScript

2012-02-21 13:55:45

JavaScript

2019-11-11 14:51:19

Java数据结构Properties

2009-11-30 16:46:29

学习Linux

2022-01-11 07:52:22

CSS 技巧代码重构

2019-12-04 10:13:58

Kubernetes存储Docker

2009-11-18 13:30:37

Oracle Sequ

2022-12-02 09:13:28

SeataAT模式

2021-04-27 08:54:43

ConcurrentH数据结构JDK8

2018-11-09 16:24:25

物联网云计算云系统

2022-11-09 08:06:15

GreatSQLMGR模式

2022-10-31 09:00:24

Promise数组参数
点赞
收藏

51CTO技术栈公众号