linq读书笔记3-操作符之select与selectmany

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,布布扣,bubuko.com

时间: 2024-12-26 02:11:11

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

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

上次我们说到了linq对数组内容的检索,自.net2.0以后,泛型成了很常见的一种应用技术,linq对泛型的检索也提供了完善的支持 如对list类型的支持,范例如下: class Program    {        static void Main(string[] args)        {            List<Books> samplebooks = new List<Books>() {                                    

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

.NET 3.5(5) - LINQ查询操作符之Select.Where.OrderBy.OrderByDescending 介绍    ·Select - Select选择:延迟    ·Where - Where查询:延迟    ·OrderBy - 按指定表达式对集合正序排序:延迟    ·OrderByDescending - 按指定表达式对集合倒序排序:延迟    ·GroupBy - 分组:延迟    ·Join - Join查询:延迟    ·GroupJoin - 分组Join查

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

本文来自:http://blog.csdn.net/xuejianwu/article/details/6931804 一.投影操作符 1. Select Select操作符对单个序列或集合中的值进行投影.下面的示例中使用select从序列中返回Employee表的所有列: [csharp] view plaincopy using (NorthwindDataContext db=new NorthwindDataContext()) { //查询语法 var query = from e i

《C#高级编程》读书笔记

<C#高级编程>读书笔记 C#类型的取值范围 名称 CTS类型 说明 范围 sbyte System.SByte 8位有符号的整数 -128~127(−27−27~27−127−1) short System.Int16 16位有符号的整数 -32 768~32 767(−215−215~215−1215−1) int System.Int32 32位有符号的整数 -2 147 483 648~2 147 483 647(−231−231~231−1231−1) long System.Int

SQLServer:《SQL必知必会》一书的读书笔记(五)

第5课 高级数据过滤 5.1 组合 WHERE 子句 第4课介绍的 WHERE 子句在过滤数据时都是用单一的条件. 5.1.1 AND 操作符 检索由供应商 DLL01 制造且价格小于等于 4 美元的所有产品的名称和价格: SELECT prod_id, prod_price, prod_name FROM Products WHERE vend_id = 'DLL01' AND prod_price <= 4; 5.1.2 OR 操作符 检索任一个指定供应商制造的所有产品的名称和价格: SEL

MySQL Cookbook读书笔记第三章

1,查询指定列/从指定列中查询 若需要指定每一列在查询结果中出现的先后顺序,可以在select语句中指定(dstuser在dsthost之后): 查询显示用户所关注的列: 2,指定查询行 使用where关键字可以查询符合条件限制的数据例如:查找srchost为venus或者srchost以s开头的行记录: 使用操作符like进行模式匹配,其中%表示通配符,代表一个差多为任意值的字符串. where使用操作符and可以查询多个条件: 条件并集: 3,格式化显示查询结果 当查询语句中没有重命名列名,

《MySQL必知必会》读书笔记_3

PS:这次的信息量有点大. 聚集不同值 SELECT AVG(DISTINCT prod_price) AS avg_price FROM products WHERE vend_id = 1003 #相同的值不会被计算 组合聚集函数 SELECT COUNT(*) AS num_items, MIN(prod_price) AS price_min, MAX(prod_price) AS price_max, AVG(prod_price) AS price_avg FROM products

MySQL Cookbook读书笔记第5章

1,字符串属性 查看系统拥有那些字符集: 若需要来自多种语言存放到同一列中,会考虑Unicode字符集(utf8或ucs2),只有它能表示多语言的字符 有些字符集支持多字节,有些只包含单字节,判断是否支持多字节的方法是对比Length()h和char_length函数的返回值来判定字符串中是否有多字节.例如使用ucs2的字节长度为6,字符数目为3. 另外虽然Unicode字符集utf8包含多字节字符,但是一个具体的字符串有可能只包含单字节字 非二进制字符串另一特征是collation,决定字符集

SQLServer:《SQL必知必会》一书的读书笔记(四)

第4课 过滤数据 4.1 使用 WHERE 子句:过滤 只检索所需数据需要指定搜索条件(即过滤条件). WHERE 子句在表名(FROM 子句)后给出,根据 WHERE 子句中指定的条件过滤. SELECT prod_name, prod_price FROM Products WHERE prod_price = 3.49; -- 分析:从 Products 表中检索两个列,只返回 prod_price 值为 3.49 的行 [提示]SQL 过滤与应用过滤: 数据也可以在应用层过滤.但是在优化