目录

写在前面

系列文章

常见关键字

总结

写在前面

前面的几篇文章算是对linq的铺垫,从本篇开始将进行linq的语法及实践。

系列文章

Linq之Lambda表达式初步认识

Linq之Lambda进阶

Linq之隐式类型、自动属性、初始化器、匿名类

Linq之扩展方法

Linq之Expression初见

Linq之Expression进阶

Linq之Expression高级篇(常用表达式类型)

常见关键字

什么情况下使用linq呢?

可以这样说,只要是实现了IEnumerable<T>接口的对象都可以使用Linq的语法来查询。

  而对于只实现了IEnumerable接口而没有实现IEnumerable<T>的对象可以通过如下的方法

  1. public static IEnumerable<TResult> Cast<TResult>(this IEnumerable source);

来将IEnumerable接口转为IEnumerable<T>(例如ArrayList)。

那么在linq中常见的关键字有那些呢?

在c#3.0中,为linq引入了一下几个关键字:from join where group into let orderby select等。

如果你用过sql,那么你对它们并不陌生。语法很简单,这里就对每个简单的列举一个例子,以便你快速的回忆起他们的用法。

from

from子句是一个Linq查询的开始,任何一个Linq语句都是以from开始,from子句指定查询的容器,和在此语句有效的局部变量。from子句的语法为:

  1. from localParameter in Source

从上面的语法你会发现和foreach何其相似。

  1. foreach(var item in source)
  2. {
  3. //循环体
  4. }

通过上面的对比,你应该对localParameter和Source有个清楚的认识了。不过在linq中Source必须是实现IEnumerable<T>的对象。下面看一个例子:

  1. class Program
  2. {
  3. static void Main(string[] args)
  4. {
  5. List<int> lstInts = new List<int>() { , , , , , , , , };
  6. IEnumerable<int> query = from i in lstInts
  7. select i;
  8. foreach (var item in query)
  9. {
  10. Console.WriteLine(item);
  11. }
  12. Console.Read();
  13. }
  14. }

结果

举得例子其实并没有实际意义,通过这样的例子,希望对linq有个大概的认识。由于source实现自IEnumerable<T>泛型接口,T可以由source推导出来,在这个例子中T为int。

那么对没有实现IEnumerable<T>而只实现IEnumerable接口的ArrayList,该如何使用linq呢?

此时,就需要我们显式指定局部变量的类型,或者是使用Cast转为IEnumerable<T>

例如:

  1. IEnumerable<int> q2 = from i in arry.Cast<int>()
  2. select i;
  3. //或者
  4. var q3 = from int i in arry
  5. select i;

select

对查询结果进行投影,有时我们并不需要所有的列,而只需要其中的某几个列的值,此时,select是非常有用的。

下面看一个例子

假如我们有这样一个类

  1. class Person
  2. {
  3. public int ID { set; get; }
  4. public string Name { set; get; }
  5. public int Age { set; get; }
  6. }

我们有这样一个集合

  1. List<Person> persons = new List<Person>()
  2. {
  3. new Person(){ ID=, Age=, Name="wolfy"},
  4. new Person(){ID=,Age=,Name="angle"}
  5. };

现在我们要取出集合中所有人的姓名,即只投影某一列。

  1. var pNames = from p in persons
  2. select p.Name;

当然我们也可以投影一个集合,此时就需要使用匿名类。

  1. var persons2 = from p in persons
  2. select new { p.Name, p.Age };
  3. //或者
  4. var persons3 = from p in persons
  5. select new { name = p.Name, age = p.Age };
  6. foreach (var item in persons3)
  7. {
  8. Console.WriteLine(item.name + " " + item.age);
  9. }

persons3中,在匿名类中,你可以显示的指定投影的列名。

where

对source中的数据进行筛选,看一个例子,选出所有的成年人的姓名。

  1. var persons4 = from p in persons
  2. where p.Age >
  3. select p.Name;

join

用法类似sql中join,将两个source以某种关系进行关联。

一个例子,查出公司为“北京能力有限公司”的人的名字和所在的公司名字。

  1. class Person
  2. {
  3. public int ID { set; get; }
  4. public string Name { set; get; }
  5. public int Age { set; get; }
  6. public int CompanyID { set; get; }
  7. }
  8. class Company
  9. {
  10. public int ID { set; get; }
  11. public string Name { set; get; }
  12. }
  1. List<Person> persons = new List<Person>()
  2. {
  3. new Person(){ ID=, Age=, Name="wolfy",CompanyID=},
  4. new Person(){ID=,Age=,Name="angle",CompanyID=}
  5. };
  6. List<Company> companys = new List<Company>()
  7. {
  8. new Company(){ ID=, Name="北京能力有限公司"},
  9. new Company(){ID=,Name="北京无能有限公司"}
  10. };
  11. var result = from p in persons
  12. join c in companys on p.CompanyID equals c.ID
  13. where c.Name=="北京能力有限公司"
  14. select new { Name = p.Name, CompanyName = c.Name };
  15. foreach (var item in result)
  16. {
  17. Console.WriteLine(item.Name + " " + item.CompanyName);
  18. }

结果

注意

join子句只能使用equals或者是not equal而不能用其他运算符(==都不行)。而equals运算符左边必须联接的左部,右边为右部,不能调换的,否则编译不能通过。

into和group

into子句用于将join或者是group子句的结果进一步持续化,包装成为一个System.Linq.IGrouping<TKey, TElement>对象,而且IGrouping继承自IEnumerable<TElement>,IGrouping接口提供分组的键和,该键下所包含的集合。

下面看一个例子

  1. List<string> lstNames = new List<string>() { "zhangsan", "lisi", "wanger", "mazi", "zhangwuji" };
  2. var result2 = from n in lstNames
  3. group n by n.Length into g
  4. select new { g.Key, values = g };
  5. foreach (var group in result2)
  6. {
  7. Console.WriteLine("{0}:", group.Key);
  8. foreach (var item in group.values)
  9. {
  10. Console.WriteLine(item);
  11. }
  12. }

结果

let

let子句用于在查询中添加一个新的局部变量,使其在后面的查询中可见,类似sql中为as关键字为字段起别名。

  1. var persons4 = from p in persons
  2. let age = p.Age
  3. where age >
  4. select p.Name;

 Take Skip

用于选取前几个或者和跳过前几个,如选择第11到20个则可以

  1. query.Skip().Take();

跳过前十个,然后再取10条数据。

OrderBy OrderByDescending

  1. query.OrderBy(c => c.Length);

总结

本篇文章介绍了在linq中常见的关键字,他们的作用可以类比sql中的用法。当然还有一些关键字,比如:Distinct Union Intersect Except,这些就不再举例了。感兴趣的可以自己动手试一试。

其它的样例代码可参考:https://code.msdn.microsoft.com/101-LINQ-Samples-3fb9811b

参考文章

http://kb.cnblogs.com/page/100043/

Linq之常见关键字的更多相关文章

  1. PHP 面向对象中常见关键字使用(final、static、const和instanceof)

    PHP 面向对象中常见关键字的使用: 1.final :final关键字可以加在类或者类中方法之前,但是不能使用final标识成员属性. 作用: 使用final标识的类,不能被继承. 在类中使用fin ...

  2. linq中let关键字学习

    linq中let关键字就是对子查询的一个别名,let子句用于在查询中添加一个新的局部变量,使其在后面的查询中可见. linq中let关键字实例 1.传统下的子查询与LET关键字的区别     C# 代 ...

  3. c/c++常见关键字解释

    c语言中常见关键字:  char :    =>声明字符型变量或函数 double :=>声明双精度变量或函数 enum :  =>声明枚举类型 float:     =>声明 ...

  4. python常见关键字的使用

    常见关键字 在循环中常见的关键字使用方法 continue:结束本次循环,继续执行下一次循环 break:跳出一个循环或者结束一个循环 例 使用用户名密码登录(有三次机会)count=0while c ...

  5. Java 常见关键字总结:final、static、this、super!

    final,static,this,super 关键字总结 final 关键字 final关键字,意思是最终的.不可修改的,最见不得变化 ,用来修饰类.方法和变量,具有以下特点: final修饰的类不 ...

  6. 1218.1——OC中的常见关键字及一些基本方法

    OC常见的关键字介绍: @ 看到这个关键字,我们就应该想到,这是Object-C对C语言的扩展,例如@interface XXX. @interface 声明类 @implementation 实现类 ...

  7. JAVA基础3——常见关键字解读(1)

    常见的JAVA中的关键字 static static静态变量 静态变量:使用static关键字定义的变量.static可以修饰变量和方法,也有static静态代码块.被static修饰的成员变量和成员 ...

  8. LINQ之let关键字

    let子句用于在LINQ表达式中存储子表达式的计算结果.let子句创建一个范围变量来存储结果,变量被创建后,不能修改或把其他表达式的结果重新赋值给它.此范围变量可以再后续的LINQ子句中使用. 实例1 ...

  9. Linq Query常见错误

    1.只能对 Type.IsGenericParameter 为 True 的类型调用方法 对于此错误,一般常见在虚拟实体,但是要把条件拼接在Expression中,通常是因为该字段在数据库中是可空的, ...

随机推荐

  1. redis 优化

    系统优化echo "vm.overcommit_memory=1" > /etc/sysctl.conf 0, 表示内核将检查是否有足够的可用内存供应用进程使用:如果有足够的 ...

  2. Dos

    一.简介 https://zh.wikipedia.org/wiki/DOS 二.系统下载 http://www.cn-dos.net/newdos/doswarea.htm 三.实用命令 1)查看系 ...

  3. Vrrp协议

    一.简介 VRRP(Virtual Router Redundancy Protocol)协议是用于实现路由器冗余的协议,最新协议在RFC3768中定义,原来的定义RFC2338被废除,新协议相对还简 ...

  4. Learning C Struct

    为什么需要结构体类型? 一种语言本身往往会提供一些最基本的数据类型,比如数字型(int,bigint,float,double等),字符型,日期型,布尔型等.但现实世界中,我们面对的对象总是非常复常, ...

  5. 解决linux部署项目后,第一次访问初始化数据源的时候很慢的问题

    先说一下场景 测试环境是linux - centos6.5,项目是分布式的,分别搭建到linux上 数据货使用的是阿里巴巴数据源 每次重启后的第一次访问会比较慢,查看日志发现 卡在这个地方 ...{d ...

  6. JavaWeb学习----JSTL标签库

    一.JSTL简介: JSTL全名为JavaServer Pages Standard Tag Library,中文名称为JSP标准标签函数库,目前最新的版本为1.2.JSTL是由JCP(Java Co ...

  7. 第2章 面向对象的设计原则(SOLID):6_开闭原则

    6. 开闭原则(Open Closed Principle,OCP) 6.1 定义 (1)一个类应该对扩展开放,对修改关闭.要求通过扩展来实现变化,而且是在不修改己有的代码情况下进行扩展,也不必改动己 ...

  8. VS 扩展推荐

    Visual Studio 工欲善其事,必先利器.本着这样的观念,对于经常使用的工具,我喜欢去研究研究,帮助我提高效率. Visual Studio Microsoft Visual Studio(简 ...

  9. 工厂模式(Factory Patter)

    1.工厂模式简介 工厂模式属于创建型模式,是专门用来创建对象的模式,抽象了实例化的过程.工厂模式分为 : 工厂方法模式.抽象工厂模式. 在学习工厂方法模式.抽象工厂之前,首先先要了解一下简单工厂模式, ...

  10. easyui添加自定义验证规则

    $.extend($.fn.validatebox.defaults.rules, { phone: { validator: function (value) { return /^(\d{3,4} ...