1.LINQ的数据源

必须可枚举的,即必须是数组或者集合
(继承了IEnumerable<T>接口就可以,注意是IEnumerable<T>,不是IEnumerable接口,不一样,继承后者只能使用foreach,不能使用linq)

 
定义:Linq 是一跨各种数据源和数据格式的数据模型;它在查询是,始终是把它作为一种对象来操作,可以使用基本相同的编码模型查询和数据的转换XML,SQL,ADO数据等;  

 
对于自定义属性类,继承CollectionBase类,实现了索引器,但是没有实现集合的函数,所以这种类是无法实现LINQ语句的,但是可以使用foreach来访问,书中讲foreach遍历的是实现了IEnumerale接口的集合,可见并不是这样的,foreach只是遍历有索引器的集合,而LINQ才真正遍历实现了IEnumerable接口的集合
复习一下集合的要求:
1.要迭代一个类,需要实现GetEnumerator()方法,返回类型是IEnumerator
2.要迭代类的成员,使用IEnumerable返回类型
  1. class farmer :CollectionBase
    {
    publicstring _name;
    publicint _age;
    public farmer(string s,int i )
    {
    _name = s;
    _age = i;
    }
    publicvoid add(farmer s)
    {
    List.Add(s);
    }
    public farmer this[int index]
    {
    set{List[index]= value;}
    get {return(farmer)List[index];}
    }
    }

      

2.LINQ的两种写法
  1. var query =from customer inthis._customerList
    where customer.City=="台北"
    letIndex=this._customerList.IndexOf(customer)
    selectnew{ customer,Index};

      

这种写法的select可以返回对象,字段,匿名类型返回的是一个新的对象(这样理解var query = new {customer,index})
------------------------------------------------------------------------------------------
  1. var query =this._customerList
    .Where(c => c.City=="台北") //这里面的C就是对象
    .Select(c =>new{ custom = c,Index=this._customerList.IndexOf(c)}); //返回的是新的query对象集合,这个集合里面装的是匿名对象'a的集合

      

这种写法中Select叫做投影运算符,是在Linq查询中从其他数据类型中创建新数据类型的技术(它可以改变结果的原始类型)
其中Select和Where的顺序可以调换
重点:只有在这种写法中才能用lambda表达式
 
Foreach 迭代时访问的其实是IEnumerator迭代器这个东西,任何实现了IEnumerator GetNumerator方法的接口,都能实现foreach的遍历
 
LINQ的数据源必须是继承了IEnumerable<T>接口的类,LINQ迭代的不仅仅是IEnuamertor迭代器,还有其他东西
 
 

from 指定数据源和范围变量

where 根据布尔表达式(由逻辑与 或 等组成)从数据源中筛选元素

select 指定查询结果中的元素所具有的类型或表现形式

group 对对查询结果按照键值进行分组

into 提供一个标示符,它可以充当对 join group 或 select 子句结果的引用

orderby 对查询出的元素进行排序

join 按照两个指定匹配条件来联接俩个数据源

let 产生一个用于查询表达式中子表达式查询结果的范围变量

迭代器块中用于向枚举数对象提供值或发出迭代结束信号。

yield return <expression>;
yield break;

计算表达式并以枚举数对象值的形式返回;expression 必须可以隐式转换为迭代器的 yield 类型。

yield 语句只能出现在 iterator 块中,该块可用作方法、运算符或访问器的体。

C#中的LINQ 基础的更多相关文章

  1. 如何在ASP.NET Core中实现一个基础的身份认证

    注:本文提到的代码示例下载地址> How to achieve a basic authorization in ASP.NET Core 如何在ASP.NET Core中实现一个基础的身份认证 ...

  2. [转]如何在ASP.NET Core中实现一个基础的身份认证

    本文转自:http://www.cnblogs.com/onecodeonescript/p/6015512.html 注:本文提到的代码示例下载地址> How to achieve a bas ...

  3. [.net 面向对象编程基础] (19) LINQ基础

    [.net 面向对象编程基础] (19)  LINQ基础 上两节我们介绍了.net的数组.集合和泛型.我们说到,数组是从以前编程语言延伸过来的一种引用类型,采用事先定义长度分配存储区域的方式.而集合是 ...

  4. LINQ基础概述

    介绍LINQ基础之前,首说一下LINQ 的历史和LINQ是什么,然后说一下学习 LINQ要了解的东西和 LINQ基础语法   LINQ 的历史 从语言方面的进化 –委托 –匿名方法 –Lambda表达 ...

  5. LINQ基础(二)

    本文主要介绍LINQ查询操作符 LINQ查询为最常用的操作符定义了一个声明语法.还有许多查询操作符可用于Enumerable类. 下面的例子需要用到LINQ基础(一)(http://www.cnblo ...

  6. LINQ基础(三)

    一.并行LINQ System.Linq名称空间中包含的类ParallelEnumerable可以分解查询的工作,使其分布在多个线程上. 尽管Enumerable类给IEnumerable<T& ...

  7. Linq基础必备

    1.linq基础必备之对象初始化器和匿名类型因果分析   3. 一:对象初始化器 1.就是在new的时候给公共属性赋值的一种方式 2. 在没有初始化器之前的时候,我们是怎么初始化的呢??? 1. 构造 ...

  8. C#3.0新增功能09 LINQ 基础01 语言集成查询

    连载目录    [已更新最新开发文章,点击查看详细] 语言集成查询 (LINQ) 是一系列直接将查询功能集成到 C# 语言的技术统称. 数据查询历来都表示为简单的字符串,没有编译时类型检查或 Inte ...

  9. C#中的Linq to Xml详解

    这篇文章主要介绍了C#中的Linq to Xml详解,本文给出转换步骤以及大量实例,讲解了生成xml.查询并修改xml.监听xml事件.处理xml流等内容,需要的朋友可以参考下 一.生成Xml 为了能 ...

随机推荐

  1. UVA - 11077 Find the Permutations (置换)

    Sorting is one of the most usedoperations in real life, where Computer Science comes into act. It is ...

  2. Nginx 源码安装和调优

    常见web架构: LAMP  =Linux+Apache+Mysql+PHP LNMP  =Linux+Nginx+Mysql+PHP   nginx概述: 知道:1  不知道:2 Nginx (&q ...

  3. 【Oracle】RAC删除节点

    环境: OS:OEL5.6 RAC:10.2.0.1.0 眼下有rac1.rac2.rac3三个节点,下面是删除rac3节点的具体过程 1.删除rac3节点上的数据库实例 [oracle@rac1 ~ ...

  4. 获取android的SDK或者手机目录路径

    获取android的SDK或者手机目录路径 Google为我们提供了API来获取SDK或者手机目录路径: 1.获取SD卡目录 File file1 = Environment.getExternalS ...

  5. poj 3913(水)

    Description You have devised a new encryption technique which encodes a message by inserting between ...

  6. Spring整合JUnit4测试使用注解引入多个配置文件

    转自:https://kanpiaoxue.iteye.com/blog/2151903 我们使用spring写junit单测的时候,有的时候我们的spring配置文件只有一个.我们在类的注释上面会这 ...

  7. php 写日志函数(原创)

    function write_log($msg,$isEcho=false,$path=''){ $path?'':$path='logs'.DIRECTORY_SEPARATOR.'log'.dat ...

  8. [Codeforces]Good Bye 2017

    A - New Year and Counting Cards #pragma comment(linker, "/STACK:102400000,102400000") #inc ...

  9. Oracle表的种类及定义

    1表的类型 1)堆组织表(heap organized tables). 当增加数据时,将使用在段中找到的第一个适合数据大小的空闲空间.当数据从表中删除时,留下的空间允许随后的insert和updat ...

  10. python3遍历选中文件夹下的文件【GUI编程】

    功能介绍 如标题 使用截图 1.第一步:运行python程序 2.第二步:点击按钮选中文件夹 3.运行结束: 1. 显示选中文件夹路径 2. 遍历打印文件夹内文件 代码 import os #程序功能 ...