LINQ学习笔记:复合查询和Lambda表达式语法
复合查询 在前一节中, 我们写了一个查询来将分解那些包含一个字母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 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |