快速业务通道

LINQ学习笔记:复合查询和Lambda表达式语法

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

复合查询

在前一节中, 我们写了一个查询来将分解那些包含一个字母a, 按长度排序, 并且最后转换成大写的字符串. 我们还有另外一种复合查询的写法:

   1: //前面我们使用的写法
   2:     string[] names = { "James","Jack","Harris"};
   3:  
   4:     IEnumerable<string> query = names.Where(n => n.Contains ("a"))
   5:     .OrderBy (n => n.Length).Select  (n => n.ToUpper( ));
   6:  
   7: //组合查询的写法
   8:     string[] names = { "James","Jack","Harris"};
   9: IEnumerable<string> q = from n in names where n.Contains("a")
  10:                     orderby n.Length
  11:                     select n.ToUpper();
  12:                             
  13: foreach(string s in q)
  14:         Console.Write(s + ","); //JACK,JAMES,HARRIS,

 

一个复合查询总是开始于from语句结束于select或者group语句. from语句声明了一个迭代变量, 此变量代表输入序列中的每一个元素, 类似foreach语法中的变量. 编译器会将复合查询翻译成Lambda表达式, 类似于foreach表达式会被翻译成调用GetEnumerator和MoveNext方法. 这意味着任何你可以使用的复合查询同样也可以使用Lambda表达式来完成. 例如上面的例子, 编译器将会翻译成这样:

   1: IEnumerable<string> q = names
   2:   .Where(n => n.Contains ("a"))
   3:   .OrderBy(n => n.Length)
   4:   .Select(n => n.ToUpper());

 

迭代变量

紧跟在from关键字之后的标识符称为迭代变量, 在我们的例子中, 迭代变量n出现在每一个查询中的每一个从句. 然后, 此变量实际上枚举了每一个从句中的不同序列中的元素:

   1: from    n in names       // n 是我们的迭代变量
   2: where   n.Contains ("a") // n = 直接来自于数组
   3: orderby n.Length         // n = 被过滤后的
   4: select  n.ToUpper();   // n = 排序过的

 

如果检查一下编译器帮我们生成的使用Lambda表达式的版本就可以看得更加清晰一点:

   1: names.Where   (n => n.Contains ("a"))
   2:      .OrderBy (n => n.Length)
   3:      .Select  (n => n.ToUpper());

 

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