linq对数据的查询方式的表达形式主要有两种:

var demo =from p in pList

      where p.id=***

select p;

var demo =pList.where(p=>p.id=***) select p;

以上是linq最近常见的两种表达形式。linq支持多种操作符的操作,下面对主要的常操作符进行说明:

select 与selectmany

select操作符声明:

public static IEnumerable<s> select<T,S>{

  this IEnumerable<T> source,

Func<T,S> selector

}

select 操作符将根据selector函数对源序列中的每个元素进行求值运算并依次返回该值,构成返回值序列.

举个简单例子:

var book= books.Select(p=>p.Name);

以上的select子句就该一个book对象序列投影到了一个字符串的对象序列,当然可以有更复杂的应用如把序列投影到一个对象等,如以下代码就是从book集合中找出publisher对象,就将序列投影到一个具体的对象上。

var publisher=from p in books

      select p.publisher

在select 返回的结果集中,其中的对象即可以是原来的对象,也可以是包含若干字段的一个新对象。

如下例:

var Books=from book in sampleBookData.Books

      select new{book.title,book.price,book.publisher.Name};

也可以写成如下形式:

var Books=from book in sampleBookData.Books

      select new{

             Title=book.title,

             Price=book.price,

            publisherName=book.publisher.Name

            };

此类操作创建出一个原数据的一个投影,也是将此类操作归类为投影的一个重要的原因。

下面来看另一个投影操作:selectmany

操作符声明:

public static IEnumerable<s> select<T,S>{

  this IEnumerable<T> source,

Func<T,IEnumerable<s>> selector

}

与select  不同 的是selectmany返回的是一个序列.

selectmany与select 不同的是它会把返回序列集合中的各个元素连接起来形成一个新的序列

具体先来比较两段代码:

var tmp=sampleBook.select(p=>p.books.author);

foreach(var item in tmp)

{

foreach(var item1 in item.author)

  {

     console.writeline(item1.name);

}

}

以上代码即我们要实现查询所有图书中的作者的信息,book对象的author属性是由author对象来组成的,所以select的的操作返回了由这些对像数组组成的对像序列,即返回了book与author,book包含了author的对像序列

下面来看selectMany的代码

var tmp=sampleBook.selectmany(p=>p.books.author);

foreach(var item in tmp)

{

  console.writeline(item.Name);

}

可以明显看出来,selectmany的代码明显简洁了很多,我们需要的是作者的信息,并不需要返回全部的序列信息,而selectmany正好可以很聪明的做到将两个序列分开后组成一个新的序列返回给我们,而这也正是我们需要的结果.

linq读书笔记3-操作符之select与selectmany的更多相关文章

  1. linq读书笔记2-查询内存中的对象

    上次我们说到了linq对数组内容的检索,自.net2.0以后,泛型成了很常见的一种应用技术,linq对泛型的检索也提供了完善的支持 如对list类型的支持,范例如下: class Program    ...

  2. linq读书笔记1-linq 初步

    至于linq是什么之类的已经有过太多的文章介绍,亦不清楚的胡朋友可以自己搜索一下便可以得到大量的答案 为了体验linq究竟能带给我们什么体验,我们直接从代码入手: string[] words = n ...

  3. Microsoft SqlServer2008技术内幕:T-Sql语言基础-读书笔记-单表查询SELECT语句元素

    1.select语句逻辑处理顺序: FORM WHERE GROUP BY HAVING SELECT OVER DISTINCT TOP ORDER BY 总结: 2.FORM子句的表名称应该带上数 ...

  4. 《Java编程思想》读书笔记-赋值操作符

    在最底层,Java中的数据是通过使用操作符来操作的.接下来我们逐一认识一些操作符. 怎么运用操作符 操作符接受一个或多个参数,并生成一个新值. 基本操作符 赋值操作符 符号:= 作用:取右边的值,把它 ...

  5. 【Linq】标准查询操作符

    A.1 聚合 聚合操作符(见表A-1),所有的结果只有一个值而不是一个序列. Average 和 Sum 针对数值 (任何内置数值类型)序列或使用委托从元素值转换为内置数值类型的元素序列. Min 和 ...

  6. .NET 3.5(5) - LINQ查询操作符之Select、Where、OrderBy、OrderByDescending

    .NET 3.5(5) - LINQ查询操作符之Select.Where.OrderBy.OrderByDescending 介绍    ·Select - Select选择:延迟    ·Where ...

  7. [读书笔记]C#学习笔记六: C#3.0Lambda表达式及Linq解析

    前言 最早使用到Lambda表达式是因为一个需求:如果一个数组是:int[] s = new int[]{1,3,5,9,14,16,22};例如只想要这个数组中小于15的元素然后重新组装成一个数组或 ...

  8. LINQ标准查询操作符(一)——select、SelectMany、Where、OrderBy、OrderByDescending、ThenBy、ThenByDescending和Reverse

    一.投影操作符 1. Select Select操作符对单个序列或集合中的值进行投影.下面的示例中使用select从序列中返回Employee表的所有列: //查询语法 var query = fro ...

  9. 读书笔记汇总 - SQL必知必会(第4版)

    本系列记录并分享学习SQL的过程,主要内容为SQL的基础概念及练习过程. 书目信息 中文名:<SQL必知必会(第4版)> 英文名:<Sams Teach Yourself SQL i ...

随机推荐

  1. HTTP协议2之基本认证--转

    http协议是无状态的, 浏览器和web服务器之间可以通过cookie来身份识别. 桌面应用程序(比如新浪桌面客户端)跟Web服务器之间是如何身份识别呢? 什么是HTTP基本认证 桌面应用程序也通过H ...

  2. css1-颜色和长度

    <!DOCTYPE html>CSS1-颜色和长度 <style>div{ /*颜色*/ color:#f00; /*前景色*/ background:#00f; /*背景色* ...

  3. Global.asax使用2

    ASP.NET中利用Application和Session统计在线人数.历史访问量 先来简单说一下ASP.NET中的Application和Session 下图是我们非常熟悉的Web应用程序的结构: ...

  4. 使用HttpClient发送GET请求

    HttpRequestMessage http_req_msg = new HttpRequestMessage(); http_req_msg.Method = HttpMethod.Get; ht ...

  5. android隐式intent使用场景解析

    Android 隐式intent相信大家都有用过,大部分场景我们用显式intent已经能满足我们的业务需求,隐式intent大部分都是用来启动系统自带的Activity或Service之类的组件.昨天 ...

  6. MVC自我学起之MVCMusic开发中遇到问题:musicstore edit方法出错的原因和解决方法

    错误提示: 存储区更新.插入或删除语句影响到了意外的行数(0).实体在加载后可能被修改或删除.刷新 ObjectStateManager 项. 解决案: 1.在view中或model中增加隐藏id 1 ...

  7. 表单提交---前端页面模拟表单提交(form)

    有些时候我们的前端页面总没有<form></form>表单,但是具体的业务时,我们又必须用表单提交才能达到我们想要的结果,LZ最近做了一些关于导出的一些功能,需要调用浏览器默认 ...

  8. 【译】JavaScript 开发者年度调查报告

    截至目前有超过了 5000 人参与了(该次调查),准确的说是 5350 人.我迫不及待的想要和大家分享一下这次调查的细节.在分享之前我想要感谢参与调查的每一个人.这是 JavaScript 社区一个伟 ...

  9. C语言基础10

    栈区间:在函数内部声明的变量都存放在栈区间,比如int char 数组 结构体 指针,只管申请,系统会自动帮我们回收,收回的时间是作用域结束之后,遵循的原则是"先进后出". int ...

  10. 指定g++ 头文件路径的方法

    问题: 尝试引用Python.h 这个头文件 g++ -o main main.cpp main.:: 错误:Python.h:没有那个文件或目录 由些可以看出是g++ 找不到指定的头文件 解决方式: ...