class RangeCartesianJoin { static void Main()//右边序列依赖于左边元素的交叉连接 使用多个from子句进行交叉 //连接和合并序列 { var query = from left in Enumerable.Range(1, 4) from right in Enumerable.Range(11, left) //left 1 2 3 4 select new { Left = left, Right = right }; //right 11 12 13 14 //query {System.Linq.Enumerable.SelectManyIterator<int,int,<>f__AnonymousType13<int,int>>} foreach (var pair in query) { Console.WriteLine("Left={0}; Right={1}", pair.Left, pair.Right); } } }
整数序列由一个简单整数范围值(1~4)作为开始。为其中每个整数创建了另外一个范围,从
11开始,包含同原始整数范围中同样多的元素。通过使用多个from子句,左边序列被连接到生
成的右边序列的每个元素。
编译器用来生成这个序列所调用的方法是SelectMany。它使用单个的输入序列(左边序列) ,
一个从左边序列任意元素上生成另外一个序列的委托,以及一个生成结果元素(其中包含了每个
序列中的元素)的委托。
和其他连接一样,如果查询表达式中连接操作后面紧跟的是select子句,那么投影就作为最后
的实参;否则,引入一个透明标识符,从而使左右序列的范围变量在后续查询中都能被访问。
输出
Left=1; Right=11
Left=2; Right=11
Left=2; Right=12
Left=3; Right=11
Left=3; Right=12
Left=3; Right=13
Left=4; Right=11
Left=4; Right=12
Left=4; Right=13
Left=4; Right=14