LINQ学习笔记:创建更加复杂查询的策略
:
1: IEnumerable<string> query = 2: from n in names 3: select Regex.Replace (n, "[aeiou]", ""); 4:
5: query = from n in query 6: where n.Length > 2 7: orderby n
8: select n;
9:
10: foreach(var name in query) 11: {
12: Console.WriteLine(name); //C.Y,Jck,Jms,Lndy 13: }
into关键字 into关键字可以让查询在经过一系列处理之后继续进行, 并且是逐步构造查询的快捷方式.使用into, 我们可以将上述的查询改写为: 1: IEnumerable<string> query = 2: from n in names 3: select Regex.Replace (n, "[aeiou]", "") 4: into noVowel
5: where noVowel.Length > 2 6: orderby noVowel
7: select noVowel;
唯一可以使用into的地方是在select或者group语句之后. Into”重新开始”一个新的查询, 并且允许你继续使用全新的where, orderby 和select语句. 作用域规则 所有的查询变量在into关键字之后都不再属于自己的作用范围, 例如下面的查询将不会被编译通过: 1: var query =
2: from n1 in names 3: select n1.ToUpper()
4: into n2
5: where n1.Contains ("x") // 非法, n1超出了作用域 6: select n2;
要了解为什么, 考虑一下将上述查询转换成Lamdba语法之后: 1: var query = names
2: .Select (n1 => n1.ToUpper())
3: .Where (n2 => n1.Contains ("x")); 当where运行的时候原始的名字(n1)已经丢失了, where操作符的输入序列只包含了大写的名字, 因此不能根据n1来过滤了. 包装查询 一个渐进查询可以被改造成一个包装查询, 如下例: var tempQuery = tempQueryExpr var finalQuery = from … in tempQuery… 也可以进一步改造为: var finalQuery = from … in (tempQueryExpr) 包装查询从语义上等同于渐进式查询或者使用into关键字(没有中间变量). 最终结果就是只有一行包含多个操作符的查询语句. 例如, 考虑下面的查询: 1: IEnumerable<string> query = 2: from n in names 3: select Regex.Replace (n, "[aeiou]", ""); 4:
5: query = from n in query 6: where n.Length < 2 7: orderby n
8: select n;
|
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |