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)方法。

  • 相关阅读:
    福大软工1816 · 第一次作业
    Python学习
    实验12——指针的基础应用2
    实验11——指针的基础应用
    实验十——一维数组的定义及引用
    实验九——基本数据类型存储及应用总结
    实验八——函数定义及调用总结
    实验七——函数定义及调用总结
    实验六——循环结构程序练习总结
    实验五——循环结构学习总结
  • 原文地址:https://www.cnblogs.com/RealAlex/p/2960892.html
Copyright © 2011-2022 走看看