2008-09-11 15 views

Répondre

124

Une jointure croisée est simplement le produit cartésien de deux ensembles. Il n'y a pas d'opérateur de jointure explicite pour cela.

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

Comment écrivez-vous que 'de p chez les personnes de c dans cars' en notation lambda? – sports

+24

'people.SelectMany (p => voitures, (p, c) => new {...})' –

21

Sur la base de la réponse de Steve, l'expression la plus simple serait:

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

La même chose avec linq méthodes d'extension:

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

A Tuple est un bon type pour le produit cartésien :

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

Méthode d'extension:

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))); 
} 

Et utiliser comme:

vals1.CrossJoin(vals2)