LINQ系列:Linq to Object投影操作符
投影是指在将序列中的元素转换为一个自定义形式的操作。投影操作符Select和SelectMany用于选择出赋予了适当功能的值。SelectMany操作符可以处理多个集合。
LINQ表达式语法:
1. Select
Select操作符对单个序列或集合中的值进行投影。
1.1 原型定义
public static IEnumerable<TResult> Select<TSource, TResult>(this IEnumerable<TSource> source, Func<TSource, TResult> selector);
public static IEnumerable<TResult> Select<TSource, TResult>(this IEnumerable<TSource> source, Func<TSource, int, TResult> selector);
1.2 查询表达式
int[] fibonacci = new int[] { , , , , , , , };
var result = from f in fibonacci
select f; foreach (var item in result)
{
Console.WriteLine(item);
}
IEnumerable<int>
source = new int[] { , , , , , , , },
filtered = source.Where(f => f > ),
sorted = filtered.OrderBy(f => f),
query = sorted.Select(f => f * );
List<int> list = new List<int>() { , , , , };
var query = from number in list
where number <
select number;
3>. 扩展方法
int[] fibonacci = new int[] { , , , , , , , };
var result = fibonacci.Select(f => f); foreach (var item in result)
{
Console.WriteLine(item);
}
Object[] arr = new Object[] { "String", , true, 10.0m, 'a' };
var types = arr.Select(item => item.GetType().Name); foreach (var type in types)
{
Console.WriteLine(type);
}
4>. 查询返回列
Select可以从序列中查询返回全部列、单独列及指定的多列。
返回单列:
using (NorthwindContext context = new NorthwindContext())
{
var products = from p in context.Products
select p.ProductName;
}
var products = context.Products
.Select(p => p.ProductName);
// using System.IO;
DirectoryInfo di = new DirectoryInfo(@"D:\");
var query = from dir in di.GetDirectories()
orderby dir.Name
select dir.Name;
返回多列:
var products = from p in context.Products
select new { p.ProductID, p.ProductName };
var products = context.Products
.Select(p => new { p.ProductID, p.ProductName });
int[] fibonacci = new int[] { , , , , , , };
var expr = fibonacci.Select((f, i) => new { Index = i, Number = f });
foreach (var item in expr)
{
Console.WriteLine(item.Index + "-" + item.Number);
}
var expr = context.Products
.OrderBy(p => p.ProductID)
.Select(p => new ProductViewModel
{
ProductID = p.ProductID,
ProductName = p.ProductName,
UnitPrice = p.UnitPrice
});
var expr = context.Products
.Select(p => new
{
ProductID = p.ProductID,
ProductName = p.ProductName,
Available = p.UnitsInStock - p.UnitsOnOrder > ? "In Stock" : "Out Of Stock"
});
var expr = context.Products
.Select(p => new
{
ProductID = p.ProductID,
ProductName = p.ProductName,
Units = new
{
p.UnitsInStock,
p.UnitsOnOrder,
Available = p.UnitsInStock - p.UnitsOnOrder > ? "In Stock" : "Out Of Stock"
}
});
var query = context.Products
.Select((p, index) => new
{
Position = index,
p.ProductName,
p.UnitPrice
});
5>. Select方法实现
public static IEnumerable<TResult> Select<TSource, TResult>(this IEnumerable<TSource> source, Func<TSource, TResult> selector)
{
foreach (TSource element in source)
{
yield return selector(element);
}
}
2. SelectMany
SelectMany操作符可以将多个from字句组合起来,将每个对象的结果合并成一个序列。
1>. 原型定义
public static IEnumerable<TResult> SelectMany<TSource, TCollection, TResult>(this IEnumerable<TSource> source, Func<TSource, IEnumerable<TCollection>> collectionSelector, Func<TSource, TCollection, TResult> resultSelector);
public static IEnumerable<TResult> SelectMany<TSource, TCollection, TResult>(this IEnumerable<TSource> source, Func<TSource, int, IEnumerable<TCollection>> collectionSelector, Func<TSource, TCollection, TResult> resultSelector);
2>. 返回全部列
var expr = from c in context.Customers
from o in c.Orders
select o;
var expr = context.Customers
.SelectMany(c => c.Orders);
3>. 返回指定列
var expr = from c in context.Customers
from o in c.Orders
select new { o.OrderID, o.OrderDate };
var expr = context.Customers
.SelectMany(c => c.Orders
.Select(o => new { o.OrderID, o.OrderDate }));
var query = context.Categories
.Where(c => c.CategoryID == )
.SelectMany(c => c.Products
.Where(p => p.CategoryID == c.CategoryID)
.Select(p => new
{
c.CategoryName,
p.ProductName,
p.UnitPrice
})
);
var expr = from c in context.Categories
from p in c.Products
where c.CategoryName == "LINQ to Object"
select p;
var query = from c in context.Categories
select new
{
CategoryID = c.CategoryID,
CategoryName = c.CategoryName,
ProductIDs = from p in c.Products
select p.ProductID
};
var expr = from c in context.Categories
from p in c.Products
select new
{
c.CategoryName,
p.ProductID,
p.ProductName
}; var expr = from c in
context.Categories
.SelectMany(c => from p in c.Products
select new
{
c.CategoryName,
p.ProductID,
p.ProductName
})
select c; var expr = context.Categories
.SelectMany(c => c.Products
.Select(p => new
{
c.CategoryName,
p.ProductID,
p.ProductName
}));
3. Let
var expr = from p in context.Products
let productInfo = p.UnitPrice + "," + p.UnitsInStock
select new { p.ProductName, productInfo };
var expr = context.Products
.Select(p => new { p, ProductInfo = p.UnitPrice + "," + p.UnitsInStock })
.Select(t => new { t.p.ProductName, t.ProductInfo }); foreach (var item in expr)
{
Console.WriteLine("{0}-{1}", item.ProductName, item.ProductInfo);
}
LINQ系列:Linq to Object投影操作符的更多相关文章
- LINQ系列目录
1. LINQ准备 1.1 C#中与LINQ相关特性 2. LINQ to Object 2.1 LINQ to Object投影操作符(Select/SelectMany/Let) 2.2 LINQ ...
- C# ~ 从 XML 到 Linq 到 Linq to XML
.XML 可扩展标记语言 (Extensible Markup Language), 标记 (markup) 是关键部分,是标准通用标记语言 (Standard Generalized Markup ...
- LINQ系列:Linq to Object集合操作符
集合操作符对元素的集合或序列集合进行操作,并返回一个集合.LINQ共有4种集合查询操作符:Distinct.Union.Intersect和Except. 1. Distinct Distinct操作 ...
- LinQ系列文章
温故而知新,想着系统再学习一次LinQ知识点,发现园子里有个非常棒的系列文章,所以Mark下来,方便以后查阅! 系列博客导航: LINQ之路系列博客导航 LINQ之路 1:LINQ介绍 LINQ之路 ...
- LINQ 系列
C#图解教程 第十九章 LINQ LINQ 什么是LINQLINQ提供程序 匿名类型 方法语法和查询语法查询变量查询表达式的结构 from子句join子句什么是联结查询主体中的from…let…w ...
- Linq系列
LINQ 图解 Linq中的Select——投影 Linq学习资源 Expert C# 5.0中的Linq部分
- C# LINQ系列:LINQ to DataSet的DataTable操作 及 DataTable与Linq相互转换
LINQ to DataSet需要使用System.Core.dll.System.Data.dll和System.Data.DataSetExtensions.dll,在项目中添加引用System. ...
- LINQ之LINQ to Objects(上)
LINQ概述 LINQ,语言集成查询(Language Integrated Query),它允许使用C#或VB代码以查询数据库相同的方式来操作不同的数据源. 1.LINQ体系结构 从上图可以看出,L ...
- Linq之Linq to Sql
目录 写在前面 系列文章 Linq to sql 总结 写在前面 上篇文章介绍了linq to xml的相关内容,linq to xml提供一种更便捷的创建xml树,及查询的途径.这篇文章将继续介绍l ...
随机推荐
- 学习CSS3动画(animation)
CSS3就是出了不少高大上的功能,3D效果.动画.多列等等.今天写篇文章记录怎么一下怎么用CSS3写一个动画. 丑话还得说前头,IE9以及以下版本不支持CSS3动画(如真要实现可以考虑用js,不过估计 ...
- 【原】iOS学习之UITabBar的隐藏
当页面使用 UITabBarController + UINavigationController 框架的时候,当跳转到详情页面的时候,如果 UITabBar 仍然存在的话就会造成逻辑混乱,用户体验也 ...
- Java Servlet规范
截自网址:http://blog.csdn.net/u010391029/article/details/46521051 JavaServlet Specification Version 2.3 ...
- BestCoder Round #80 1002
HDU 5666 Segment 题意:给你条斜率为-1,常数项为q(q为质数)的直线,连接原点与直线上整数格点,问你在有多少个格点在形成的无数个三角形内,而不在线段上,结果对P取模. 思路:best ...
- Android自定义折线图
老师布置了个作业:http://www.cnblogs.com/qingxu/p/5316897.html 作业中提到的 “玩了几天以后,大家发现了一些很有意思的现象,比如黄金点在逐渐地往下移动.” ...
- JQuery的一些简单功能
JQuery js的缺点总结 1.入口函数只能有一个,如果出现多个,后面的会覆盖掉前面的 2.代码容错性差,容易出错,出错会导致后面的代码不执行 3.存在浏览器兼容性,比如innerText在火狐浏览 ...
- URL的截取问题
$(function (){ if (window.location.href.includes('?')) { if (window.location.href.split('?')[1].spli ...
- nodejs redis 发布订阅机制封装
最近项目使用redis,对publish 和 subscribe的使用进行了了解,并进行了封装. var config = require('../config/config'); var log = ...
- Docker Volume 之权限管理(转)
Volume数据卷是Docker的一个重要概念.数据卷是可供一个或多个容器使用的特殊目录,可以为容器应用存储提供有价值的特性: 持久化数据与容器的生命周期解耦:在容器删除之后数据卷中的内容可以保持.D ...
- Linux 升级glibc-2.14 失败 我遇到的问题
直接说步骤和流程: 1.到http://www.gnu.org/software/libc/下载最新版本,我这里下载了glibc-2.14.tar.gz 这个版本,解压到任意目录准备编译(/usr/l ...