代码改变世界

开发人员眼中的LINQ

2008-05-13 07:45  $等待$  阅读(358)  评论(0编辑  收藏  举报

在今年的三月份,微软发布了最新一代的开发平台Visual Studio 2008.Visual Studio 2008中提供了太多的新功能与新特性.这些新功能与新特性都极大地提高了开发人员的效率.提到Visual Studio 2008的新特性就不得不说LINQ,LINQ的全称是Language Integrated Query.语言级集成查询.下面将详细地介绍在Visual Studio 2008中如何使用LINQ.下图是LINQ的一个整体的框架.主要包括LINQ To Objects,LINQ To SQL,LINQ To XML.几个方面.下面会详细讲述LINQ的各种用法

先来看一个LINQ查询的实例:

 1using System;
 2
 3using System.Linq; //使用LINQ查询的命名空间
 4
 5static class HelloWorld
 6
 7{
 8
 9 static void Main()
10
11 {
12
13    string[] words = "hello""wonderful""linq""beautiful""world" };
14
15    // 查询字符长度小于5的字符串
16
17   var shortWords =
18
19      from word in words
20
21      where word.Length <= 5
22
23      select word;
24
25    // 打印字符串
26
27    foreach (var word in shortWords)
28
29      Console.WriteLine(word);
30
31 }

32
33}

34
35


Visual Studio 2008中使用LINQ查询,系统会自动添加对using System.Linq这个命名空间的引用.上述的实例实现从数组words中选取字符长度小于5的字符串并将该字符串打印出来.

仔细查看一下LINQ查询的语法,会发现LINQ查询语句跟SQL语句似曾相识.它是一种类SQL的语言.使用Var来定义变量是C#3.0中的新特性.使用它可以定义任何类型的变量.from,in,select,where 都是LINQ查询的关键字.LINQ的查询语法是from在前select在后.

如果没有LINQ,使用其它的方式对数组进行查询就会比较的麻烦,使用LINQ可以提前编码的效率.

下面将一步一步演示如何在Visual Studio 2008中使用LINQ查询.

1)第一步需要添加一个LINQ To SQL Classes文件.使用LINQ To SQL Classes文件可以自动完成数据表到实体的OR/M映射.

2)第二步,把要查询的数据表拖放到LINQ To SQL Classes文件中,比如把数据库AdventureWorks中的Product表拖到到LINQ To SQL Classes文件中,如下图所示:

假定LINQ To SQL Classes文件名字为NorthWind,那么你查看NorthWind.Designer.cs文件就会发现映射后的Product表.

 1 [System.Data.Linq.Mapping.DatabaseAttribute(Name="AdventureWorks")]
 2
 3   public partial class NorthWindDataContext : System.Data.Linq.DataContext
 4
 5   {
 6
 7      
 8
 9      private static System.Data.Linq.Mapping.MappingSource mappingSource = 
10
11            new AttributeMappingSource();
12
13.
14
15.
16
17}

18
19


  
在这个文件中包括对表中每一个字段的映射,如

 1[Column(Storage="_ProductID", AutoSync=AutoSync.OnInsert, DbType="Int NOT NULL IDENTITY", IsPrimaryKey=true, IsDbGenerated=true)]
 2
 3      public int ProductID
 4
 5      {
 6
 7        get
 8
 9        {
10
11           return this._ProductID;
12
13        }

14
15         set
16
17        {
18
19           if ((this._ProductID != value))
20
21           {
22
23              this.OnProductIDChanging(value);
24
25              this.SendPropertyChanging();
26
27              this._ProductID = value;
28
29              this.SendPropertyChanged("ProductID");
30
31              this.OnProductIDChanged();
32
33           }

34
35        }

36
37     }

38
39


     
Visual Studio 2008中使用LINQ非常的简单,下面将来实现一个简单的LINQ实例.新建一个Web页面,然后在这个Web页面上拖放一个DataGrid 控件,使用LINQ从映射后的数据表中查询数据然后把这些数据填充到DataGrid.


在这里,重点介绍几个类,这将对理解LINQ有很大的帮助.

DataContext

 

 DataContext类型(数据上下文)是System.Data.Linq命名空间下的重要类型,用于把查询句法翻译成SQL语句,以及把数据从数据库返回给调用方和把实体的修改写入数据库。

 DataContext提供了以下功能:

1)    以日志形式记录DataContext生成的SQL

2)    执行SQL(包括查询和更新语句)

3)    创建和删除数据库

DataContext是实体和数据库之间的桥梁,NorthWindDataContext就是继承自DataContext,所以我们可以使用NorthWindDataContext的对象对映射后的数据表进行查询.

在上面的实例中,就是从Products这张表中选取属性SafetyStockLevel 大于800的数据记录:

from product in northwindDataBase.Products

                                        where product.SafetyStockLevel > 800

                                        select product;

查询的如下:

下面来看一个使用LINQ来操作XML的实例.

using System;

using System.Linq;

using System.Xml;

using System.Xml.Linq;

static class HelloLinqToXml

{

 
static void Main()

 
{

    var books 
= new[] {

      
new {Title="Ajax in Action", Publisher="Manning", Year=2005 },

      
new {Title="Windows Forms in Action", Publisher="Manning", Year=2006 },

      
new {Title="RSS and Atom in Action", Publisher="Manning", Year=2006 }

    }
;

    XElement xml 
= new XElement("books",

      from book 
in books

      
where book.Year == 2006

      select 
new XElement("book",

        
new XAttribute("title", book.Title),

        
new XElement("publisher", book.Publisher)

      )

    );

    Console.WriteLine(xml);

 }


}



生成的结果如下:

      XMLElement 用来构建XML元素,并且可以使用LINQ以查询的方式来得到XML元素的各个属性.查询语法还是经典的from in where select 组合.

LINQ TO XML 允许数据能够通过使用标准的查询操作符来进行查询.它能够提供类似于XPath的导航.在各种层次的XML结点间进行导航.比如父结点和子结点,兄弟结点之间等.使用它比使用之前的DOM来操作XML来得更简单一些.

以上就是在Visual Studio 2008中使用LINQ的一点体会,后面还会有详细的文章来介绍LINQ方面的内容.