LINQ(入门)

转载 2012年03月23日 10:35:12

    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语句转换为一些列的语句块,例如:

隐藏行号 复制代码 C#
  1. string[] strs = new String[] {"One","Two","Three" };
    
  2. foreach (String s in strs)
    
  3. {
    
  4.     Console.WriteLine(s);
    
  5. }
    
  6. 
    

     转换为:

隐藏行号 复制代码 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. }
    
  7. 
    

 

    在.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. }
    
  15. 
    

 
    题外话:如何为已知类型扩展方法:只需一个静态类和静态方法,在静态方法中参数使用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. }
    
  8. 
    

 

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;
    
  4. 
    

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

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. 
    
  7.         public Programer()
    
  8.         {
    
  9.         }
    
  10.     }
    
  11. 
    
隐藏行号 复制代码 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. 
    
  7. var queryPs = from p in ps
    
  8.               where p.Language == "C#"
    
  9.               select new { Name = p.Name, Position = p.Position };
    
  10. 
    
  11.            
    
  12. foreach (var p in queryPs)
    
  13. {
    
  14.     Console.WriteLine(String.Format("Name:{0}\t\tPosition:{1}", p.Name, p.Position));
    
  15. }
    
  16. 
    

 

查询的执行时间
  上述例子中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();
    
  4. 
    
  5. 
    

LINQ体验(13)——LINQ to SQL语句之运算符转换和ADO.NET与LINQ to SQL

运算符转换 1.AsEnumerable:将类型转换为泛型 IEnumerable 使用 AsEnumerable 可返回类型化为泛型 IEnumerable 的参数。在此示例中,LINQ...
  • u013948191
  • u013948191
  • 2015年08月11日 09:55
  • 1083

LINQ to SQL 系列 如何使用LINQ to SQL插入、修改、删除数据

LINQ和 LINQ to SQL 都已经不是一个新事物了,但是我接触的比较晚,本着绝知此事要躬行的态度,决定写这个系列。   本文使用的测试环境是VS 2010,和sql server ...
  • CsethCRM
  • CsethCRM
  • 2014年03月11日 11:46
  • 8242

mybatis for net用法(转载)

这是一篇转载文章。 转载地址: http://www.cnblogs.com/chenkai/archive/2011/03/21/1990596.html ...
  • chenqiangdage
  • chenqiangdage
  • 2015年07月10日 23:23
  • 1117

C# 中的 LINQ 入门

  • 2012年04月19日 11:55
  • 1.09MB
  • 下载

C#_3.0_LinQ入门系列

  • 2013年04月27日 08:43
  • 1.9MB
  • 下载

LINQ入门及应用 源代码

  • 2010年04月20日 08:33
  • 8.02MB
  • 下载

Linq入门(word)

  • 2008年11月04日 18:42
  • 911KB
  • 下载

linq入门到掌握word版学习质料

  • 2011年04月25日 11:21
  • 791KB
  • 下载

跟我一起学Visual Studio 2008系列课程(3):语言集成查询(LINQ)之入门篇 (Level 200)

  • 2010年05月18日 11:06
  • 13.49MB
  • 下载

linq入门到精通的学习笔记

  • 2011年05月13日 14:32
  • 621KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:LINQ(入门)
举报原因:
原因补充:

(最多只允许输入30个字)