快速业务通道

LINQ学习笔记:Join和Group Join

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-03-13

使用下面的select子查询也可以得到同样的结果:

   1: from c in customers
   2:  
   3: select new
   4:  
   5: {
   6:  
   7:   CustName = c.Name,
   8:  
   9:   custPurchases =
  10:  
  11:     purchases.Where (p => c.ID == p.CustomerID)
  12:  
  13: };

 

默认情况下, GroupJoin相当于一个左外连接. 为了得到一个inner join, 我们必须在custPurcahse上面做一层过滤:

   1: from c in customers join p in purchases
   2:  
   3:   on c.ID equals p.CustomerID
   4:  
   5: into custPurchases
   6:  
   7: where custPurchases.Any( )
   8:  
   9: select ...

 

在group-join之后的into操作作用于内部元素的子序列, 而不是每一个单独的子元素, 因此如果你要过滤每一个单独的采购单, 你必须在joining之前调用Where

   1: from c in customers
   2:  
   3: join p in purchases.Where (p2 => p2.Price > 1000)
   4:  
   5:   on c.ID equals p.CustomerID
   6:  
   7: into custPurchases ...

 

扁平的Outer Joins

当你想得到一个Outer Join同时输出扁平的结果集的时候, 这会是一个两难的境地. GroupJoin会提供给你Outer Join; Join提供给你扁平的结果集. 因此, 解决方案是先调用GroupJoin, 然后在每一个子序列上面调用DefaultIfEmpty, 最后调用SelectMany:

   1: from c in customers
   2:  
   3: join p in purchases on c.ID equals p.CustomerID
   4:  
   5: into custPurchases
   6:  
   7: from cp in custPurchases.DefaultIfEmpty( )
   8:  
   9: select new
  10:  
  11: {
  12:  
  13:   CustName = c.Name,
  14:  
  15:   Price = cp == null ? (decimal?) null : cp.Price
  16:  
  17: };

 

当Purchases为空的时候DefaultIfEmpty会得到一个null值. 第二个from语句被翻译成SelectMany, 它扩展和压扁了所有的purchase, 并将它们联合在一起形成purchase元素所属的单一序列

连接和Lookups

Enumerable当中的Join和GroupJoin使用两个步骤来工作. 首先, 它们将inner序列加载到一个lookup当中, 然后再将一个outer序列和这个lookup组合在一起.

一个lookup是一个分组序列, 并且可以通过键直接访问, 或者你可以认为它是一个序列字典, 每一个键可以接受多个元素. 并且lookup是只读的, 定以如下:

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号