1.闲言碎语

由于项目的需要接触到Linq,刚开始有些不适应,好多概念都很模糊。不过经过一段时间的摸索,慢慢地对Linq有了一个更加深入的了解。在此记录一下备忘。

     2.查询表达式语法

执行Linq有两种方式,一种是方法形式eg:names.Contains('K');,另一种就是查询表达式eg:var query=from n in names select n; 下面用代码来详细解释。

string[] fruitName = { "Apple", "Pear", "Cherry", "Banana", "orange" };
IEnumerable<string> query = from f in fruitName
where f.Contains("a")
orderby f.Length
select f.ToUpper();
foreach (var str in query) {
Console.WriteLine(str);
}

查询变量:简单来说就是保存查询的变量但不是查询结果,它是一个可以枚举的类型,也就是说可以用IEnumberable或var类型保存查询结果。只有在foreach它的时候才返回查询结果。用上面的code来说query就是一个查询变量

查询表达式:查询表达式由一组用类似于 SQL 或 XQuery 的声明性语法编写的子句组成。每个子句又包含一个或多个 C# 表达式,而这些表达式本身又可能是查询表达式或包含查询表达式。--摘自MSDN

查询表达式语法:查询表达式必须以 from 子句开头,并且必须以 select 或 group 子句结尾。在第一个 from 子句和最后一个 select 或 group 子句之间,查询表达式可以包含一个或多个下列可选子句:where、orderby、join、let 甚至附加的 from 子句。还可以使用 into 关键字使 join 或 group 子句的结果能够充当同一查询表达式中附加查询子句的源。---摘自MSDN

查询表达式关键字详解:

from:它是查询表达式的开头,同时它又定义了范围变量(Range Variable)和指定数据源。

范围变量类似于 foreach 语句中的迭代变量,eg:

foreach(string n in names){
}

上面的code中n就相当于范围变量。要注意的一点是范围变量指向的序列会随着查询子句执行而变化eg:

string[] fruitName = { "Apple", "Pear", "Cherry", "Banana", "orange" };
IEnumerable<string> query = from f in fruitName//f是我们定义的范围变量
where f.Contains("a")//f直接来自fruitName数组
orderby f.Length//f来自Where过滤后的序列
select f.ToUpper();//f来自orderby排序后的序列
foreach (var str in query) {
Console.WriteLine(str);
}

let:用来在保持范围变量的同时引入新的查询变量。eg:

string[] fruitName = { "Apple", "Pear", "Cherry", "Banana", "orange" };
IEnumerable<string> query = from f in fruitName
let v=Regex.Replace(n,”[aeiou]","")
where v.Length>
select f;//f在这里任然有效
foreach (var str in query) {
Console.WriteLine(str);
}

select:用来指示输出查询结果的类型,用于数据转换(或投影)

group:用来对数据分组,还sql中的分组概念一样。

where:用来过滤符合条件的序列项

orderby:根据指定的只来排序(升序或降序)

join:对两个序列中键匹配的元素进行连接,常用的连接有

  • 内部联接

  • 分组联接

  • 左外部联接

group:按照指定的键值进行分组

into:在查询完以后可以继续查询

子查询:嵌套from查询,和sql子查询概念一样。

大家一看就能明白这些关键字就是为Linq to sql而准备的

Linq之查询表达式语法详解的更多相关文章

  1. C#3.0新增功能09 LINQ 标准查询运算符 02 查询表达式语法

    连载目录    [已更新最新开发文章,点击查看详细] 某些使用更频繁的标准查询运算符具有专用的 C# 语言关键字语法,使用这些语法可以在查询表达式中调用这些运算符. 查询表达式是比基于方法的等效项更具 ...

  2. Hadoop Hive sql语法详解

    Hadoop Hive sql语法详解 Hive 是基于Hadoop 构建的一套数据仓库分析系统,它提供了丰富的SQL查询方式来分析存储在Hadoop 分布式文件系统中的数据,可以将结构 化的数据文件 ...

  3. Thymeleaf3语法详解和实战

    Thymeleaf3语法详解 Thymeleaf是Spring boot推荐使用的模版引擎,除此之外常见的还有Freemarker和Jsp.Jsp应该是我们最早接触的模版引擎.而Freemarker工 ...

  4. Xpath语法详解

    1.简介 XPath是一门在XML和HTML文档中查找信息的语言,可以用来在XML和HTML文档中对元素和属性进行遍历 XPath的安装 Chrome插件XPath Helper 点Chrome浏览器 ...

  5. Java Spring cron表达式使用详解

    Java Spring cron表达式使用详解   By:授客 QQ:1033553122 语法格式 Seconds Minutes Hours DayofMonth Month DayofWeek ...

  6. Java8的Stream语法详解(转载)

    1. Stream初体验 我们先来看看Java里面是怎么定义Stream的: A sequence of elements supporting sequential and parallel agg ...

  7. [持续交付实践] pipeline使用:语法详解

    一.引言 jenkins pipeline语法的发展如此之快用日新月异来形容也不为过,而目前国内对jenkins pipeline关注的人还非常少,相关的文章更是稀少,唯一看到w3c有篇相关的估计是直 ...

  8. Java 8系列之Stream的基本语法详解

    本文转至:https://blog.csdn.net/io_field/article/details/54971761 Stream系列: Java 8系列之Stream的基本语法详解 Java 8 ...

  9. spring AspectJ切入点语法详解 记录以便查阅

    AspectJ切入点语法详解 6.5.1  Spring AOP支持的AspectJ切入点指示符 切入点指示符用来指示切入点表达式目的,,在Spring AOP中目前只有执行方法这一个连接点,Spri ...

随机推荐

  1. Could not resolve this reference. Could not locate the assembly

    Rebuild Project 的时候提示找不到NewtonJson 组件,重新添加了Dll(Newtonsoft.Json.dll),依然抛错. 解决办法,将Dll(Newtonsoft.Json. ...

  2. 学习使用LaTex排版文字输出为pdf(1)

    学习用latex写我的简历. 我在ubuntu环境下,先下载所需软件,命令百度就可以. 先创建一个a.tex,写上 \documentclass{article} \usepackage{CJK} \ ...

  3. 你真的理解z-index吗?

    一.前言 假如只是开发简单的弹窗效果,懂得通过z-index来调整元素间的层叠关系就够了.但要将多个弹窗间层叠关系给处理好,那么充分理解z-index背后的原理及兼容性问题就是必要的知识储备了.本文作 ...

  4. 信息图形(Infographic)

    信息图形(Infographic),又称为信息图,是指数据.信息或知识的可视化表现形式.信息图形主要应用于必须要有一个清楚准确的解释或表达甚为复杂且大量的信息,例如在各式各样的文件档案上.各个地图及标 ...

  5. BochsDebug

    Bochs User Manual   Chapter 8. Tips and Techniques   8.12. Using Bochs internal debugger Note, if yo ...

  6. 利用Jquery处理跨域请求

    在项目制作过程中,可能会用到ajax来提高用户体验,这里终于研究出来,利用jquery来进行跨域请求,在用$.getJSON这个方法时,前台页面中需这样写 $.getJSON(“需要提交处理的url? ...

  7. ARC————自动引用计数

    一.内存管理/引用计数 1.引用计数式内存管理的方式(下面四种) 对象操作 OC方法 生成并持有对象 alloc/new/copy/mutableCopyd等方法 持有对象 retain方法 释放对象 ...

  8. jQuery控制TR的显示隐藏

    网上有很多,这里介绍三种: 第一种方法,就是使用id,这个方法可以在生成html的时候动态设置tr的id,也是用得最多最简单的一种,如下: <table> <tr><td ...

  9. C# 执行JS

    需引用命名空间:Microsoft.VsaMicrosoft.JScript using System; using System.Collections.Generic; using System. ...

  10. jquery easyui combobox

    $("#select_Dic").combobox({                        url: "http://www.cnblogs.com/Ajax/ ...