快速业务通道

LINQ学习笔记:Join和Group Join

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

最后的结果选择器表达式创建了输出序列中的每一个元素, 如果你还有额外的查询语句需要去执行, 例如orderby:

   1: from c in customers
   2:  
   3: join p in purchases on c.ID equals p.CustomerID
   4:  
   5: orderby p.Price
   6:  
   7: select c.Name + ” bought a “ + p.Description;

 

在Lambda方式中, 我们就必须在结果选择器表达式中去生成一个临时的匿名类型. 这样可以保持c和p在同一个join作用范围内:

   1: customers.Join (               // outer collection
   2:  
   3:       purchases,               // inner collection
   4:  
   5:       c => c.ID,               // outer key selector
   6:  
   7:       p => p.CustomerID,       // inner key selector
   8:  
   9:       (c, p) => new { c, p } ) // result selector
  10:  
  11:  .OrderBy (x => x.p.Price)
  12:  
  13:  .Select (x => x.c.Name + ” bought a “
  14:  
  15:                         + x.p.Description);

 

可以看得出来复合查询语法更加的直观一点, 这也是在使用joining操作时推荐的做法.

GroupJoin

GroupJoin功能与Join类似, 只不过GroupJoin返回的结果集是一个层级结构, 而不是一个扁平的结构. 对于复合语法来说, GroupJoin和Join是一样的, 只不过它通常会跟着一个into关键字:

   1: var query =
   2:  
   3:   from c in customers
   4:  
   5:   join p in purchases on c.ID equals p.CustomerID
   6:  
   7:   into custPurchases
   8:  
   9:   select custPurchases;

 

只有当into语句出现在一个join语句之后它才会被翻译成GroupJoin. 如果是跟在一个select或者group语句之后, 则意味着是查询延续. 这两个用法是非常不同的, 但它们有一个共同的特点: 两者都引入了新的查询变量

上述查询结果是一个序列的序列, 我们可以像下面这样来枚举它:

   1: foreach (IEnumerable purchaseSequence in query)
   2:  
   3:   foreach (Purchase p in purchaseSequence)
   4:  
   5:     Console.WriteLine (p.Description);

 

另外我们也可以在返回结果中来选取外部的查询变量:

   1: from c in customers
   2:  
   3: join p in purchases on c.ID equals p.CustomerID
   4:  
   5: into custPurchases
   6:  
   7: select new { CustName = c.Name, custPurchases }; //c可以被引用到

 

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站: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号