LINQ

LINQ通过提供一种跨各种数据源和数据格式使用数据的一致模型。在LINQ查询中,始终会用到对象。可以使用相同的基本编码模式来查询和转换XML文档、SQL数据库、ADO.NET数据集、NET集合中的数据以及对其LINQ提供程序可用的任何其他格式的数据。

查询操作的三个部分

1.获取数据源。2.创建查询。3.执行查询

        '1.Data Source
        Dim numbers() As Integer = {0, 1, 2, 3, 4, 5}

        '2.Query creation
        'numbers is an IEnumerable<integer>
        Dim evensQuery = From num In numbers
                         Where num Mod 2 = 0
                         Select num

        '3.Query execution
        For Each number In evensQuery
            Console.WriteLine(number & " ")
        Next

在LINQ中,查询的执行和查询本身截然不同;换句话说,如果是创建查询变量,则不会检索任何数据。

数据源

由于上面实例中,数据源是数组,因此它隐式支持泛型IEnumerable(of T)接口。这一事实意味着该数据源可以用LINQ进行查询。在foreach语句中执行查询,而Foreach要求使用IEnumerable或IEnumerable(of T)。支持IEnumerable(of T)或派生接口(如泛型IQueryable(of T))的类型称为"“可查询类型”。

查询

查询指定要从数据源中检索的信息。查询还可以指定在返回这些信息之前如何对其进行排序、分组和结构化。查询存储在查询变量中,并用查询表达式进行初始化。

上一个示例中的查询从整数数组中返回所有偶数。该查询表达式包含三个子句:from、where和select。from子句指定数据源,where子句应用筛选器,select子句指定返回的元素。

需要注意的是,在LINQ中,查询变量本身不执行任何操作并且不返回任何数据。它只是存储在以后某个时刻执行查询时为生成结果而必需的信息。

查询执行

延迟执行。如前所述,查询变量本身只是存储查询命令。实际的查询执行会延迟到在foreach语句中循环访问查询变量时发生。此概念称为“延迟执行”

强制立即执行。对一系列源元素执行聚合函数的查询必须首先循环访问这些元素。Count,Max,Average和first就属于此类查询。

若要强制立即执行任意查询并缓存其结果,可以调用ToList(Of T)或ToArray(of T)方法。

posted @ 2013-03-15 10:30  暴走小白  阅读(189)  评论(0编辑  收藏  举报