zoukankan      html  css  js  c++  java
  • 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)方法。

  • 相关阅读:
    javascript之数组操作
    python中的类中属性元素加self.和不加self.的区别
    Q查询
    jQuery EasyUI的各历史版本和应用
    了解Entity Framework中事务处理
    C#中Abstract和Virtual的区别
    控制器post参数接收
    存储过程调用存储过程
    表变量、临时表(with as ,create table)
    LINQ TO SQL 实现无限递归查询
  • 原文地址:https://www.cnblogs.com/RealAlex/p/2960892.html
Copyright © 2011-2022 走看看