LINQ即语言集成查询,是.NET Framework 3.5中新增的功能。其功能类似于数据库中的SQL语句(实际上LINQ就是针对.NET Framework的SQL):提供标准的、易于学习的查询和更新数据模式。
从from开始
用过SQL的朋友都知道,最简单的SQL语句SELECT record FROM tableName:获取表中的所有记录,那么对应于LINQ,其语法如下:
from record in tableName select record。
明显的差异是将from语句放到了句首,此种语法方式只是为了适应Visual Studio中智能提示(试想如果将from子句放在后面,先输入select语句,此时select的对象类型尚不确定,智能提示无法做出相应提示)
SQL语句是从数据库表中查询出记录,而LINQ适应的数据源更广,包括SQL Server数据库、XML文档、ADO.NET数据集以及所有支持IEnumerable及IEnumerable<T>接口的任意对象集合。
LINQ只是一种语法
LINQ查询语句实际上和我们常用的foreach语句相似:中间语言(IL)中并没有对应的foreach语句,编译器最终会将foreach语句转换为一些列的语句块,例如:

  1. string[] strs = new String[] {"One","Two","Three" };
    
  2. foreach (String s in strs)
    
  3. {
    
  4.     Console.WriteLine(s);
    
  5. }
    

转换为:

隐藏行号 复制代码 ? C#
  1. string[] strs = new String[] {"One","Two","Three" };
    
  2. IEnumerator e = strs.GetEnumerator();
    
  3. while (e.MoveNext())
    
  4. {
    
  5.     Console.WriteLine(e.Current);
    
  6. }
    

在.NET Framework 3.5中为IEnumerable<T>接口加入了大量的扩展方法,这些方法为LINQ提供了实现基础(就像IEnumerable中GetEnumerator方法为foreach提供实现基础一样)
例如,IEnumerable中的Where扩展方法,它和LINQ中的where子句对应,用于筛选数据:

隐藏行号 复制代码 ? C#
  1. //使1用?Where方?法¨
    
  2.  IEnumerable<String> query = strs.Where(s => s.StartsWith("T"));
    
  3. foreach (String s in query)
    
  4. {
    
  5.     Console.WriteLine(s);
    
  6. }
    
  7. //使1用?query语?句?
    
  8. query = from s in strs
    
  9.         where s.StartsWith("T")
    
  10.         select s;
    
  11. foreach (String s in query)
    
  12. {
    
  13.     Console.WriteLine(s);
    
  14. }
    

题外话:如何为已知类型扩展方法:只需一个静态类和静态方法,在静态方法中参数使用this关键字,以下为String类型新增一个AppendA方法:

隐藏行号 复制代码 ? C#
  1. public static class Extension
    
  2. {
    
  3.     public static String AppendA(this String ins)
    
  4.     {
    
  5.         return ins + "AAA";
    
  6.     }
    
  7. }
    

var关键字与匿名类型
var关键字指示编译器推断出变量的类型,例如:
var s = "Hello";
编译器最终将s变量推断为String类型,即最终按
String s = "Hello";
来生成中间代码
在LINQ中我们可以通过var关键字来声明查询对象,而无需清楚最终我们查询返回的具体类型:

隐藏行号 复制代码 ? C#
  1. var query = from s in strs
    
  2.         where s.StartsWith("T")
    
  3.         select s;
    

另一种情况,有时我们只需要返回对象的某些属性,此时我们无需定义返回数据的类型,直接使用匿名类型:

1:  var xxx = new { F1 = "Hello", F2 = "Hello2" };
2:   

以下查询只返回Programer类的Name和Position属性:

隐藏行号 复制代码 ? C#
  1. public class Programer
    
  2.     {
    
  3.         public String Name { get; set; }
    
  4.         public String Language { get; set; }
    
  5.         public String Position { get; set; }
    
  6.         public Programer()
    
  7.         {
    
  8.         }
    
  9.     }
    
隐藏行号 复制代码 ? C#
  1. Programer[] ps = new Programer[] {
    
  2.     new Programer(){ Name="张?三y", Language="C#", Position="Leader"},
    
  3.     new Programer(){ Name="李?四?", Language="C#", Position="Coder"},
    
  4.     new Programer(){ Name="王?五?", Language="Java", Position="Coder"}
    
  5. };
    
  6. var queryPs = from p in ps
    
  7.               where p.Language == "C#"
    
  8.               select new { Name = p.Name, Position = p.Position };
    
  9. foreach (var p in queryPs)
    
  10. {
    
  11.     Console.WriteLine(String.Format("Name:{0}\t\tPosition:{1}", p.Name, p.Position));
    
  12. }
    

查询的执行时间
上述例子中LINQ语句是在foreach语句时才真正执行的,定义时只是定义了查询语句,在进入foreach枚举时才真正执行查询语句。如果我们在定义时需要立即返回查询结果可以使用ToArray或ToList方法(这两个方法也是在.Net Fromework 3.5中为IEnumerable接口新增的扩展方法)。

隐藏行号 复制代码 ? C#
  1. var queryPs = (from p in ps
    
  2.               where p.Language == "C#"
    
  3.               select new { Name = p.Name, Position = p.Position }).ToArray();
    

[转]Linq语法一的更多相关文章

  1. 从零开始学 Web 之 ES6(三)ES6基础语法一

    大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:ht ...

  2. Linq语法和C#6.0

    一. linq 1.简介: 能用linq实现的基本都可以用扩展方法实现: 举例: 查询ID>1的狗有如下两种写法 (1)var  r1=dogs.where(d=>d.id>1) ( ...

  3. Razor基础语法一

    目录: 什么是Razor? 渲染HTML Razor语法 隐式 Razor 表达式 显式 Razor 表达式 什么是Razor? Razor是基于服务端代码转换成网页的标记语法.语法主要包括Razor ...

  4. Python语法一

    前记,今天开始学习Python 参考 笨方法学习+Python(第三版) 因为有编程基础,所以入门不难,相比于以前学过的其它语言编程,Python当然也有它独特的语法格式. 1.安装Python 访问 ...

  5. 数据库 SQL语法一

    建立表语句 CREATE TABLE TABLENAME(COL_NAME1 TYPE,COL_NAME2 TYPE,......); 常用TYPE说明 INT 正数 CHAR(LENGTH) 定长字 ...

  6. Objective-C( 语法一)

    点语法 点语法的本质是方法调用 成员变量的作用域 @public : 在任何地方都能直接访问对象的成员变量 @private : 只能在当前类的对象方法中直接访问(@implementation中默认 ...

  7. robotframework基本语法一

    *** Settings *** Library OperatingSystem #Settings:导入测试库,资源文件,变量文件,为创建测试套件和test cases定义元数据 *** Varia ...

  8. java基本语法一

    1 关键字和保留字 1.1 关键字 关键字的定义:被java语言赋予了特殊含义,用做专门用途的字符串(单词). 关键字的特点:关键字中的所有字母都是小写. 1.2 保留字 java保留字:现有Java ...

  9. MySQL语法一:数据定义语句

    MySQL语句语法主要分为以下三大类: 一.数据定义语句DDL(CREATE,ALTER,DROP,DECLARE) 数据定义语句是用于修改表结构的. 一).语法提炼: 二).由上图可知,数据定义语句 ...

随机推荐

  1. DB2安装步骤

    ##################################DB2的安装########################### ## 安装前准备 ## 关闭内存地址随机化机制 vi /etc/ ...

  2. Android自动化----adb shell,appium,uiautomator2

    1.区别 1,adb shell脚本的方式 不但可以在有电脑的情况下使用,通过数据线连接电脑然后adb shell命令,而且还可以打包成app,在手机的终端使用adb shell命令. 2,appiu ...

  3. ssh证书生成与配置

    cd /usr/local/nginx/conf openssl genrsa -des3 - //key文件为私钥 openssl rsa -in tmp.key -out aminglinux.k ...

  4. Linux系统之ssh命令

    ssh命令用于远程登录上Linux主机. 常用格式:ssh [-l login_name] [-p port] [user@]hostname更详细的可以用ssh -h查看. 不指定用户: ssh 1 ...

  5. c语言定义指针类型需注意事项

    1)在定义说明语句中,指针变量名之前的星号“*“是指针变量的修饰符,也就是说它所修饰的变量是指针变量. 2)指针变量是用它们所指向的对象类型来区分的.如定义 int *ip,类型int并不是指针的类型 ...

  6. 001 开发环境搭建、安卓项目结构、R文件位置、asset目录创建

    1.安卓开发平台搭建 (1)下载SDK基础工具包(自己的百度云中) (2)将下载的安装包(android-sdk_r24.4.1-windows.zip)解压后,放到以下路径 C:\SoftAppli ...

  7. java nio 之MappedByteBuffer

    其实掌握MappedByteBuffer并不难,只要记住"三方三法三特性"(我自己总结的,呵呵~~不要扔鸡蛋哦...)这句话就可以轻松搞定!MappedByteBuffer 只是一 ...

  8. hadoop单机配置

    条件: 先下载VMware1.2,然后安装. 下载ubuntu-1.4.05-desktop-amd64.iso.下载地址:http://mirrors.aliyun.com/ubuntu-relea ...

  9. ora-1652

    ###检查是否有temp 在使用 step 2: 检查是否有事务使用到temp,并且进行删除. SELECT vt.inst_id,vs.sid,vs.serial#,vs.username,vs.o ...

  10. Mockjs详细使用说明

    Mock.js 是一款前端开发中拦截Ajax请求再生成随机数据响应的工具.可以用来模拟服务器响应. 优点是非常简单方便, 无侵入性, 基本覆盖常用的接口数据类型. 在我们的生产实际中,后端的接口往往是 ...