Linq 的使用方法

来源:互联网 发布:淘宝宝贝收藏软件 编辑:程序博客网 时间:2024/05/18 04:26

LINQLanguage Integrated Query的简称,它是集成在.NET编程语言中的一种特性。已成为编程语言的一个组成部分,在编写程序时可以得到很好的编译时语法检查,丰富的元数据,智能感知、静态类型等强类型语言的好处。并且它同时还使得查询可以方便地对内存中的信息进行查询而不仅仅只是外部数据源。

LINQ定义了一组标准查询操作符用于在所有基于.NET平台的编程语言中更加直接地声明跨越、过滤和投射操作的统一方式,标准查询操作符允许查询作用于所有基于IEnumerable<T>接口的源,并且它还允许适合于目标域或技术的第三方特定域操作符来扩大标准查询操作符集,更重要的是,第三方操作符可以用它们自己的提供附加服务的实现来自由地替换标准查询操作符,根据LINQ模式的习俗,这些查询喜欢采用与标准查询操作符相同的语言集成和工具支持。

我们来总体看看LINQ结构

.NET3.5下,微软为我们提供了一些命名空间

LINQ包括五个部分:LINQ to ObjectsLINQ to DataSetsLINQ to SQLLINQ to EntitiesLINQ to XML

LINQ to SQL全称基于关系数据的.NET语言集成查询,用于以对象形式管理关系数据,并提供了丰富的查询功能。其创建于公共语言类型系统中的基于SQL的模式定义的集成之上,当保持关系型模型表达能力和对底层存储的直接查询评测的性能时,这个集成在关系型数据之上提供强类型。

LINQ to XMLSystem.Xml.LINQ命名空间下实现对XML的操作。采用高效、易用、内存中的XML工具在宿主编程语言中提供XPath/XQuery功能等。

说了这么多,我们还是用一个简单的实例说明一下LINQ带来的体验。

第一步:创建dbmlDatabase Mark Language。数据库描述语言,是一种xml格式的文档,用来描述数据库)文件,以Northwind数据库为例,上述Customers类被映射成一个表,对应数据库中的 Customers

第二步:创建一个ASP.NET页面,在页面上加入一个GridView控件

第三步:编写代码进行数据绑定

第四步:运行显示结果。

Where操作

适用场景:实现过滤,查询等功能。

说明:SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子句。

Where操作包括3种形式,分别为简单形式、关系条件形式、First()形式。下面分别用实例举例下:

1.简单形式:

var q =

    from c in db.Customers

    where c.City == "London"

    select c;

var q =

    from e in db.Employees

    where e.HireDate >= new DateTime(1994, 1, 1)

    select e;

2.关系条件形式:

var q =

    from p in db.Products

    where p.UnitsInStock <= p.ReorderLevel && !p.Discontinued

    select p;

var q =

    from p in db.Products

    where p.UnitPrice > 10m || p.Discontinued

    select p;

var q =

    db.Products.Where(p=>p.UnitPrice > 10m).Where(p=>p.Discontinued);

3.First()形式:

返回集合中的一个元素,其实质就是在SQL语句中加TOP (1)

Shipper shipper = db.Shippers.First();

Customer cust = db.Customers.First(c => c.CustomerID == "BONAP");

Order ord = db.Orders.First(o => o.Freight > 10.00M);

LINQ to SQL句之Select/DistinctCount/Sum/Min/Max/Avg

Select/Distinct操作符

适用场景 数据查询。

说明:和SQL命令中的select作用相似但位置不同,查询表达式中的select及所接子句是放在表达式最后并把子句中的变量也就是结果返回回来;延迟。

Select/Distinct操作包括9种形式,分别为简单形式、匿名类型形式、带条件形式、指定类型形式、过滤类型形式、shaped类型形式、嵌套类型形式、LocalMethodCall形式、Distinct形式。

1.简单形式:

var q =

    from c in db.Customers

    select c.ContactName;

注意:这个语句只是一个声明或者一个描述,并没有真正把数据取出来,只有当你需要该数据的时候,它才会执行这个语句,这就是延迟加载(deferred loading)。如果,在声明的时候就返回的结果集是对象的集合。你可以使用ToList() ToArray()方法把查询结果先进行保存,然后再对这个集合进行查询。当然延迟加载(deferred loading)可以像拼接SQL语句那样拼接查询语法,再执行它。

2.匿名类型形式:

说明:匿名类型是C#3.0中新特性。其实质是编译器根据我们自定义自动产生一个匿名的类来帮助我们实现临时变量的存储。匿名类型还依赖于另外一个特性:支持根据property来创建对象。比如,var d = new { Name = "s" };编译器自动产生一个有property叫做Name的匿名类,然后按这个类型配置内存,并初始化对象。但是var d = new {"s"};是编译不通过的。因为,编译器不知道匿名类中的property的名字。例如string c = "d";var d = new { c}; 则是可以通过编译的。编译器会创建一个叫做匿名类带有叫cproperty
例如下例:new{c,ContactName,c.Phone};ContactNamePhone都是在映射文件中定义与表中字段相对应的property。编译器读入数据并创建对象时,会创建一个匿名类,这个类有两个属性,为ContactNamePhone,然后根据数据初始化对象。另外编译器还可以重命名property的名字。

var q =

    from c in db.Customers

    select new {c.ContactName, c.Phone};

语句描述:查询顾客的联系人和电话。

var q =

    from e in db.Employees

    select new

    {

        Name = e.FirstName + " " + e.LastName,

        Phone = e.HomePhone

    };

语句描述:查询职员的姓名和家庭电话

var q =

    from p in db.Products

    select new

    {

        p.ProductID,

        HalfPrice = p.UnitPrice / 2

    };

3.带条件形式:

说明:生成SQL语句为:case when condition then else

var q =

    from p in db.Products

    select new

    {

        p.ProductName,

        Availability =

        p.UnitsInStock - p.UnitsOnOrder < 0 ?

        "Out Of Stock" : "In Stock"

    };

4.指定类型形式:

说明:该形式返回你自定义类型的对象集。

var q =

    from e in db.Employees

    select new Name

    {

        FirstName = e.FirstName,

        LastName = e.LastName

    };

5.过滤类型形式:

说明:结合where使用,起到过滤作用。

var q =

    from c in db.Customers

    where c.City == "London"

    select c.ContactName;

6.shaped类型形式:

说明:其select操作使用了匿名对象,而这个匿名对象中,其属性也是个匿名对象。

var q =

    from c in db.Customers

    select new {

        c.CustomerID,

        CompanyInfo = new {c.CompanyName, c.City, c.Country},

        ContactInfo = new {c.ContactName, c.ContactTitle}

    };

语句描述:查询顾客的ID和公司信息(公司名称,城市,国家)以及联系信息(联系人和职位)。

7.嵌套类型形式:

说明:返回的对象集中的每个对象DiscountedProducts属性中,又包含一个集合。也就是每个对象也是一个集合类。

var q =

    from o in db.Orders

    select new {

        o.OrderID,

        DiscountedProducts =

            from od in o.OrderDetails

            where od.Discount > 0.0

            select od,

        FreeShippingDiscount = o.Freight

    };

8.LocalMethodCall形式:

这个例子InternationalPhone调用本地方法PhoneNumberConverter

var q = from c in db.Customers

         where c.Country == "UK" || c.Country == "USA"

         select new

         {

             c.CustomerID,

             c.CompanyName,

             Phone = c.Phone,

             InternationalPhone =

             PhoneNumberConverter(c.Country, c.Phone)

         };

PhoneNumberConverter方法如下:

public string PhoneNumberConverter(string Country, string Phone)

{

    Phone = Phone.Replace(" ", "").Replace(")", ")-");

    switch (Country)

    {

        case "USA":

            return "1-" + Phone;

        case "UK":

            return "44-" + Phone;

        default:

            return Phone;

    }

}

下面也是使用了这个方法

XDocument doc = new XDocument(

    new XElement("Customers", from c in db.Customers

              where c.Country == "UK" || c.Country == "USA"

              select (new XElement("Customer",

                      new XAttribute("CustomerID", c.CustomerID),

                      new XAttribute("CompanyName", c.CompanyName),

                      new XAttribute("InterationalPhone",

                       PhoneNumberConverter(c.Country, c.Phone))

                     ))));

9.Distinct形式:

说明:筛选字段中不相同的值。用于查询不重复的结果集。生成SQL语句为:SELECT DISTINCT [City] FROM [Customers]

var q = (

    from c in db.Customers

    select c.City )

    .Distinct();

语句描述:查询顾客覆盖的国家。