2008-09-11 11 views

答えて

124

クロス結合は、単に2つのセットのデカルト積です。そのための明示的な結合演算子はありません。

 
var combo = from p in people 
      from c in cars 
      select new 
      { 
       p.Name, 
       c.Make, 
       c.Model, 
       c.Colour 
      }; 
+1

? – sports

+24

'people.SelectMany(p => cars、(p、c)=>新しい{...})' –

21

スティーブの回答に基づいて、最も単純な式はこのようになります:

var combo = from Person in people 
      from Car in cars 
      select new {Person, Car}; 
24

linq拡張メソッドと同じこと:

var names = new string[] { "Ana", "Raz", "John" }; 
var numbers = new int[] { 1, 2, 3 }; 
var newList=names.SelectMany(
    x => numbers, 
    (y, z) => { return y + z + " test "; }); 
foreach (var item in newList) 
{ 
    Console.WriteLine(item); 
} 
9

Tupleは、デカルト製品の良いタイプです:

public static IEnumerable<Tuple<T1, T2>> CrossJoin<T1, T2>(IEnumerable<T1> sequence1, IEnumerable<T2> sequence2) 
{ 
    return sequence1.SelectMany(t1 => sequence2.Select(t2 => Tuple.Create(t1, t2))); 
} 
3

拡張メソッド:

public static IEnumerable<Tuple<T1, T2>> CrossJoin<T1, T2>(this IEnumerable<T1> sequence1, IEnumerable<T2> sequence2) 
{ 
    return sequence1.SelectMany(t1 => sequence2.Select(t2 => Tuple.Create(t1, t2))); 
} 

などを使用します。あなたはその `ラムダ表記でcars`におけるCからの人々のpからの書き込みにはどうすればよい

vals1.CrossJoin(vals2) 
関連する問題