22.C#分组和查询延续及选择综合症(十一章11.6-11.7)
对于昨天的连接还有一个知识点没有说,那就是分组连接。是11.5中的内容,补上。
分组连接的格式:join 元素 in 序列
on 条件表达式
into 新的序列
内连接和分组连接之间的一个重要差异(即分组连接和普通分组之间的差异)是,对于分组连接来说,在左边序列和结果序列之间是一对一的对应关系,即使左边序列中的某些元素在右边序列没有任何匹配的元素,也无所谓。这是非常重要的,有时会用于模拟SQL的左外连接。在左边元素不匹配任何右边元素的时候,嵌入序列就是空的。与内连接一样,分组连接要对右边序列进行缓冲,而对左边序列进行流处理。看代码吧。
//使用分组连接
var result7 = from box in boxList
join item in list on box.jewelleryType equals item.Type into items
select new { box, items };
//使用分组连接给我的感觉就好像将一系列的珠宝(具有相同属性值),进行打包,当然生成的也是一个序列,而上
//述中的box则作为存放这些一些相同属性珠宝的标识
Console.WriteLine(result7.Count()); foreach (var re in result7)
{
Console.WriteLine(re.box.BoxName);
foreach (var item in re.items)
{
Console.WriteLine(item.Price);
}
}
这里的代码是接着昨天的代码的,哈哈,可能要看看上一篇文章。
- 使用多个from子句进行交叉连接和合并序列
到目前为止,我们学到的连接都是相等连接--左边序列中的元素和右边序列要进行匹配。交叉连接不在序列之间执行任何匹配操作,它只尽可能列出所有的可能。我们新建一个类,叫Customer
class Customer
{
public string Name { get; set; }
}
List<Jewellery> list = new List<Jewellery>()
{
new Jewellery() {Type=Jewellery.JewelleryType.Bracelet,State=Jewellery.JewelleryState.Repair,Price= },
new Jewellery() {Type=Jewellery.JewelleryType.Necklace,State=Jewellery.JewelleryState.Sold,Price= },
new Jewellery() {Type=Jewellery.JewelleryType.Ring,State=Jewellery.JewelleryState.Stock,Price= },
new Jewellery() {Type=Jewellery.JewelleryType.Necklace,State=Jewellery.JewelleryState.Sold,Price= },
new Jewellery() {Type=Jewellery.JewelleryType.Bracelet,State=Jewellery.JewelleryState.Stock,Price= },
new Jewellery() {Type=Jewellery.JewelleryType.Ring,State=Jewellery.JewelleryState.Repair,Price= }
}; List<Customer> ctrList = new List<Customer>()
{
new Customer() {Name="" },
new Customer() {Name="" },
new Customer() {Name="" },
new Customer() {Name="" },
new Customer() {Name="" }
}; var result9 = from ctr in ctrList
from jly in list
select new { ctr, jly };
Console.WriteLine(result9.Count());
结果为30,因为珠宝有6件,顾客有5人,5*6=30。可见,使用两个from子句可能交叉连接返回所有组合的序列。
- 使用group...by子句进行分组
格式:group 元素 by 关键字
grouping表达式通过其键来决定序列如何分组。整个结果是一个序列,序列中的每个元素本身就是投影后元素的序列,还具有一个Key属性,即用于分组的键。下面来做一个操作,用珠宝的类型进行分组。
var result10 = from jly in list
group jly by jly.Type; Console.WriteLine(result10.Count()); foreach (var jlys in result10)
{
Console.WriteLine(jlys.Key);
foreach(var jly in jlys)
{
Console.WriteLine(jly.Price);
}
}
感觉和使用join...into子句出来的效果是一样的,但是使用group...by更能让人理解。
- 查询延续
查询延续提供了一种方式,把一个查询表达式的结果用作另一个查询表达式的初始序列。它可以应用于group..by和select子句上,语法对于两者是一样的,只需要使用上下文关键字into,如要查询每种类型珠宝的数量,可以这样表示。
var result11 = from jly in list
group jly by jly.Type into jlys
select new { Type = jlys.Key, Count = jlys.Count() }; foreach(var item in result11)
{
Console.WriteLine(item.Type);
Console.WriteLine(item.Count);
}
结果为:
表明每一种类型都有两件珠宝。
- 使用LINQ表达式还是使用扩展方法
对于如何选择,每个心中都有数,这里只说下两者的关系。
每个查询表达式都可能使用扩展方法来表示,但很多LING操作在C#中不存在等价的查询表达式。
请斧正,抱一个学习的心态认真地做一件事情。
22.C#分组和查询延续及选择综合症(十一章11.6-11.7)的更多相关文章
- CPrimerPlus第十一章中的“选择排序算法”学习
C Primer Plus第十一章字符串排序程序11.25中,涉及到“选择排序算法”,这也是找工作笔试或面试可能会遇到的题目,下面谈谈自己的理解. 举个例子:对数组num[5]={3,5,2,1,4} ...
- 【MySQL】条件查询之排序聚合分组分页查询
排序查询 语法:order by 子句 order by 排序字段1 排序方式1 , 排序字段2 排序方式2... 排序方式: ASC:升序,默认的. DESC:降序. 注意: 如果有多个排序条件,则 ...
- SQL Fundamentals: 分组统计查询(FROM-WHERE-GROUPBY-HAVING-SELECT-ORDER BY)
SQL Fundamentals || Oracle SQL语言 统计函数 单字段分组统计(GROUP BY) 多字段分组统计 HAVING子句 控制操作的显示列:基本的SELECT语句 控制行:限定 ...
- Oracle数据库从入门到精通-分组统计查询
视频课程:李兴华 Oracle从入门到精通 视频课程学习者:阳光罗诺 视频来源:51CTO学院 整体内容: 统计函数的使用 分组统计查询的实现 对分组的数据过滤 统计函数 在之前我们就学习过一个COU ...
- 010.简单查询、分组统计查询、多表连接查询(sql实例)
-------------------------------------day3------------ --添加多行数据:------INSERT [INTO] 表名 [(列的列表)] --SEL ...
- sql 分组统计查询并横纵坐标转换
关于sql 分组统计查询,我们在做报表的时候经常需要用到;今天就在这里整理下; 先附上一段sql代码: if object_id(N'#mytb',N'U') is not null drop tab ...
- mysql加强(3)~分组(统计)查询
一.分组(统计) 查询 1.语法 : select [distinct] *| 分组字段1[别名] [,分组字段2[别名],...] | 统计函数 from 表名 [别名] [where 条件(s)] ...
- ORM( ORM查询13种方法3. 单表的双下划线的使用 4. 外键的方法 5. 多对多的方法 ,聚合,分组,F查询,Q查询,事务 )
必知必会13条 <1> all(): 查询所有结果 <2> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或 ...
- mysql 更新与查询(排序 分组 链接查询)
UPDATE更新 #每一次数据的更新都需要update UPDATE 命令修改 MySQL 数据表数据的通用 SQL 语法: UPDATE table_name SET field1=new-valu ...
随机推荐
- Less里css表达式的写法
项目中用的grunt-contrib-less, 写了以下less代码 .mapfix{ position: fixed; top:10px; width: 430px; z-index: 100; ...
- nyoj 237 游戏高手的烦恼 二分匹配--最小点覆盖
题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=237 二分匹配--最小点覆盖模板题 Tips:用邻接矩阵超时,用数组模拟邻接表WA,暂时只 ...
- hdu 3064 twoNumber
twoNumber Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 2048/1024 K (Java/Others) Total Su ...
- zoj 3229 Shoot the Bullet(无源汇上下界最大流)
题目:Shoot the Bullet 收藏:http://www.tuicool.com/articles/QRr2Qb 把每一天看成一个点,每个女孩也看成一个点,增加源和汇s.t,源向每一天连上[ ...
- 有用的MySQL语句
摘自onefish资料库 1. 计算年数你想通过生日来计算这个人有几岁了. SELECT DATE_FORMAT(FROM_DAYS(TO_DAYS(now()) - TO_DAYS(@dateofb ...
- 《精解Windows 10》
<精解Windows 10>全面深入讲解Windows 10操作系统的使用方法.本书共计14章内容.第一章简述Windows 10操作系统的一些变革:第二章介绍Modern 2.0界面的体 ...
- Mango Weekly Training Round #3 解题报告
A. Codeforces 92A Chips 签到题.. #include <iostream> #include <cstdio> #include <cstring ...
- 给定一个整数实现奇偶bit位互换
1.分别取出所有奇数bit位和偶数bit位 0x55555555(对应二进制奇数bit位为1,偶数bit位全为0)&num 0xaaaaaaaa(对应二进制即偶数bit位为1,奇数bit位全为 ...
- 第22章 DLL注入和API拦截(3)
22.6 API拦截的一个例子 22.6.1 通过覆盖代码来拦截API (1)实现过程 ①在内存中对要拦截的函数(假设是Kernel32.dll中的ExitProcess)进行定位,从而得到它的内存地 ...
- Unity脚本生命周期
前言 说到生命周期,影响最深刻的是,在接触Java的JSF组件时,JSF组件的五大生命周期,全要默写出来,嘿嘿…… 总结这两天在写小怪和掉落的糖葫芦时,老是遇到GameObject未销毁,一直存在场景 ...