2008-09-11 22 views

Trả lời

124

Nối chéo đơn giản là sản phẩm Descartes của hai bộ. Không có toán tử join rõ ràng cho nó.

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

Làm thế nào để bạn viết rằng 'từ p ở những người từ c trong cars' trong ký hiệu lambda? – sports

+24

'people.SelectMany (p => ô tô, (p, c) => mới {...})' –

21

Dựa trên câu trả lời của Steve, khái niệm đơn giản nhất sẽ là:

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

Các điều tương tự với phương pháp linq mở rộng:

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

Một Tuple là một loại tốt cho sản phẩm Descartes :

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

Phương pháp mở rộng:

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

Và sử dụng như:

vals1.CrossJoin(vals2) 
Các vấn đề liên quan