このブラウザーはサポートされなくなりました。

Microsoft Edge にアップグレードすると、最新の機能、セキュリティ更新プログラム、およびテクニカル サポートを利用できます。

Microsoft Edge をダウンロードする Internet Explorer と Microsoft Edge の詳細情報 GroupJoin<TOuter,TInner,TKey,TResult>(IEnumerable<TOuter>, IEnumerable<TInner>, Func<TOuter,TKey>, Func<TInner,TKey>, Func<TOuter,IEnumerable<TInner>, TResult>, IEqualityComparer<TKey>)

キーが等しいかどうかに基づいて 2 つのシーケンスの要素を相互に関連付け、その結果をグループ化します。 指定された IEqualityComparer<T> を使用してキーを比較します。

GroupJoin<TOuter,TInner,TKey,TResult>(IEnumerable<TOuter>, IEnumerable<TInner>, Func<TOuter,TKey>, Func<TInner,TKey>, Func<TOuter,IEnumerable<TInner>, TResult>)

キーが等しいかどうかに基づいて 2 つのシーケンスの要素を相互に関連付け、その結果をグループ化します。 キーの比較には既定の等値比較子が使用されます。

GroupJoin<TOuter,TInner,TKey,TResult>(IEnumerable<TOuter>, IEnumerable<TInner>, Func<TOuter,TKey>, Func<TInner,TKey>, Func<TOuter,IEnumerable<TInner>, TResult>, IEqualityComparer<TKey>)
public:
generic <typename TOuter, typename TInner, typename TKey, typename TResult>
[System::Runtime::CompilerServices::Extension]
 static System::Collections::Generic::IEnumerable<TResult> ^ GroupJoin(System::Collections::Generic::IEnumerable<TOuter> ^ outer, System::Collections::Generic::IEnumerable<TInner> ^ inner, Func<TOuter, TKey> ^ outerKeySelector, Func<TInner, TKey> ^ innerKeySelector, Func<TOuter, System::Collections::Generic::IEnumerable<TInner> ^, TResult> ^ resultSelector, System::Collections::Generic::IEqualityComparer<TKey> ^ comparer);
public static System.Collections.Generic.IEnumerable<TResult> GroupJoin<TOuter,TInner,TKey,TResult> (this System.Collections.Generic.IEnumerable<TOuter> outer, System.Collections.Generic.IEnumerable<TInner> inner, Func<TOuter,TKey> outerKeySelector, Func<TInner,TKey> innerKeySelector, Func<TOuter,System.Collections.Generic.IEnumerable<TInner>,TResult> resultSelector, System.Collections.Generic.IEqualityComparer<TKey> comparer);
public static System.Collections.Generic.IEnumerable<TResult> GroupJoin<TOuter,TInner,TKey,TResult> (this System.Collections.Generic.IEnumerable<TOuter> outer, System.Collections.Generic.IEnumerable<TInner> inner, Func<TOuter,TKey> outerKeySelector, Func<TInner,TKey> innerKeySelector, Func<TOuter,System.Collections.Generic.IEnumerable<TInner>,TResult> resultSelector, System.Collections.Generic.IEqualityComparer<TKey>? comparer);
static member GroupJoin : seq<'Outer> * seq<'Inner> * Func<'Outer, 'Key> * Func<'Inner, 'Key> * Func<'Outer, seq<'Inner>, 'Result> * System.Collections.Generic.IEqualityComparer<'Key> -> seq<'Result>
<Extension()>
Public Function GroupJoin(Of TOuter, TInner, TKey, TResult) (outer As IEnumerable(Of TOuter), inner As IEnumerable(Of TInner), outerKeySelector As Func(Of TOuter, TKey), innerKeySelector As Func(Of TInner, TKey), resultSelector As Func(Of TOuter, IEnumerable(Of TInner), TResult), comparer As IEqualityComparer(Of TKey)) As IEnumerable(Of TResult)

型パラメーター

TOuter

このメソッドは、遅延実行を使用して実装されます。 即時戻り値は、アクションの実行に必要なすべての情報を格納する オブジェクトです。 か、呼び出すことによって、オブジェクトが列挙されるまで、このメソッドによって表されるクエリは実行されません、 GetEnumerator メソッドを使用して直接または foreach Visual C# または For Each Visual Basic で。

null の場合 comparer 、キーのハッシュと比較には、 Default 既定の等値比較子 である が使用されます。

GroupJoin は階層的な結果を生成します。つまり、 の outer 要素は、 の一致する要素 inner のコレクションとペアになります。 GroupJoin を使用すると、 の各要素 outer に対する一致のセット全体に基づいて結果を作成できます。

の特定の outer 要素に inner 関連付けられた要素がない場合、その要素の一致のシーケンスは空になりますが、結果には引き続き表示されます。

関数は resultSelector 、要素ごとに outer 1 回だけ呼び出され、要素と一致するすべての inner 要素のコレクションが outer 呼び出されます。 これは、 Join の 1 つの要素と から 1 つの要素 outer を含むペアで結果セレクター関数が呼び出されるメソッドとは inner 異なります。

GroupJoin の要素 outer の順序を保持し、 の各要素に outer 対して、 の inner 一致する要素の順序を保持します。

GroupJoin には、従来のリレーショナル データベースの用語に直接相当するものはありません。 ただし、このメソッドでは内部結合と左外部結合のスーパーセットが実装されます。 これらの操作はどちらも、グループ化結合の観点から記述できます。 詳細については、「 結合操作 」を参照してください。

GroupJoin<TOuter,TInner,TKey,TResult>(IEnumerable<TOuter>, IEnumerable<TInner>, Func<TOuter,TKey>, Func<TInner,TKey>, Func<TOuter,IEnumerable<TInner>, TResult>)
public:
generic <typename TOuter, typename TInner, typename TKey, typename TResult>
[System::Runtime::CompilerServices::Extension]
 static System::Collections::Generic::IEnumerable<TResult> ^ GroupJoin(System::Collections::Generic::IEnumerable<TOuter> ^ outer, System::Collections::Generic::IEnumerable<TInner> ^ inner, Func<TOuter, TKey> ^ outerKeySelector, Func<TInner, TKey> ^ innerKeySelector, Func<TOuter, System::Collections::Generic::IEnumerable<TInner> ^, TResult> ^ resultSelector);
public static System.Collections.Generic.IEnumerable<TResult> GroupJoin<TOuter,TInner,TKey,TResult> (this System.Collections.Generic.IEnumerable<TOuter> outer, System.Collections.Generic.IEnumerable<TInner> inner, Func<TOuter,TKey> outerKeySelector, Func<TInner,TKey> innerKeySelector, Func<TOuter,System.Collections.Generic.IEnumerable<TInner>,TResult> resultSelector);
static member GroupJoin : seq<'Outer> * seq<'Inner> * Func<'Outer, 'Key> * Func<'Inner, 'Key> * Func<'Outer, seq<'Inner>, 'Result> -> seq<'Result>
<Extension()>
Public Function GroupJoin(Of TOuter, TInner, TKey, TResult) (outer As IEnumerable(Of TOuter), inner As IEnumerable(Of TInner), outerKeySelector As Func(Of TOuter, TKey), innerKeySelector As Func(Of TInner, TKey), resultSelector As Func(Of TOuter, IEnumerable(Of TInner), TResult)) As IEnumerable(Of TResult)

型パラメーター

TOuter

次のコード例では、 を使用 GroupJoin<TOuter,TInner,TKey,TResult>(IEnumerable<TOuter>, IEnumerable<TInner>, Func<TOuter,TKey>, Func<TInner,TKey>, Func<TOuter,IEnumerable<TInner>, TResult>) して、2 つのシーケンスでグループ化結合を実行する方法を示します。

class Person public string Name { get; set; } class Pet public string Name { get; set; } public Person Owner { get; set; } public static void GroupJoinEx1() Person magnus = new Person { Name = "Hedlund, Magnus" }; Person terry = new Person { Name = "Adams, Terry" }; Person charlotte = new Person { Name = "Weiss, Charlotte" }; Pet barley = new Pet { Name = "Barley", Owner = terry }; Pet boots = new Pet { Name = "Boots", Owner = terry }; Pet whiskers = new Pet { Name = "Whiskers", Owner = charlotte }; Pet daisy = new Pet { Name = "Daisy", Owner = magnus }; List<Person> people = new List<Person> { magnus, terry, charlotte }; List<Pet> pets = new List<Pet> { barley, boots, whiskers, daisy }; // Create a list where each element is an anonymous // type that contains a person's name and // a collection of names of the pets they own. var query = people.GroupJoin(pets, person => person, pet => pet.Owner, (person, petCollection) => OwnerName = person.Name, Pets = petCollection.Select(pet => pet.Name) foreach (var obj in query) // Output the owner's name. Console.WriteLine("{0}:", obj.OwnerName); // Output each of the owner's pet's names. foreach (string pet in obj.Pets) Console.WriteLine(" {0}", pet); This code produces the following output: Hedlund, Magnus: Daisy Adams, Terry: Barley Boots Weiss, Charlotte: Whiskers Structure Person Public Name As String End Structure Structure Pet Public Name As String Public Owner As Person End Structure Sub GroupJoinEx1() Dim magnus As New Person With {.Name = "Hedlund, Magnus"} Dim terry As New Person With {.Name = "Adams, Terry"} Dim charlotte As New Person With {.Name = "Weiss, Charlotte"} Dim barley As New Pet With {.Name = "Barley", .Owner = terry} Dim boots As New Pet With {.Name = "Boots", .Owner = terry} Dim whiskers As New Pet With {.Name = "Whiskers", .Owner = charlotte} Dim daisy As New Pet With {.Name = "Daisy", .Owner = magnus} Dim people As New List(Of Person)(New Person() {magnus, terry, charlotte}) Dim pets As New List(Of Pet)(New Pet() {barley, boots, whiskers, daisy}) ' Create a collection where each element is an anonymous type ' that contains a Person's name and a collection of names of ' the pets that are owned by them. Dim query = people.GroupJoin(pets, Function(person) person, Function(pet) pet.Owner, Function(person, petCollection) _ New With {.OwnerName = person.Name, .Pets = petCollection.Select( Function(pet) pet.Name)}) Dim output As New System.Text.StringBuilder For Each obj In query ' Output the owner's name. output.AppendLine(obj.OwnerName & ":") ' Output each of the owner's pet's names. For Each pet As String In obj.Pets output.AppendLine(" " & pet) ' Display the output. Console.WriteLine(output.ToString) End Sub ' This code produces the following output: ' Hedlund, Magnus ' Daisy ' Adams, Terry ' Barley ' Boots ' Weiss, Charlotte ' Whiskers

このメソッドは、遅延実行を使用して実装されます。 即時戻り値は、アクションの実行に必要なすべての情報を格納する オブジェクトです。 か、呼び出すことによって、オブジェクトが列挙されるまで、このメソッドによって表されるクエリは実行されません、 GetEnumerator メソッドを使用して直接または foreach Visual C# または For Each Visual Basic で。

既定の等値比較子 は、 Default キーのハッシュと比較に使用されます。

GroupJoin は階層的な結果を生成します。つまり、 の outer 要素は、 の一致する要素 inner のコレクションとペアになります。 GroupJoin を使用すると、 の各要素 outer に対する一致のセット全体に基づいて結果を作成できます。

の特定の outer 要素に inner 関連付けられた要素がない場合、その要素の一致のシーケンスは空になりますが、結果には引き続き表示されます。

関数は resultSelector 、要素ごとに outer 1 回だけ呼び出され、要素と一致するすべての inner 要素のコレクションが outer 呼び出されます。 これは、 の要素と Join から inner 1 つの要素 outer を含むペアで結果セレクター関数が呼び出される メソッドとは異なります。

GroupJoin の要素 outer の順序を保持し、 の各要素に outer 対して、 の inner 一致する要素の順序を保持します。

GroupJoin には、従来のリレーショナル データベースの用語に直接相当するものはありません。 ただし、このメソッドでは内部結合と左外部結合のスーパーセットが実装されます。 これらの操作はどちらも、グループ化結合の観点から記述できます。 詳細については、「 結合操作 」を参照してください。

クエリ式の構文で、 join ... into (Visual C#) または Group Join の呼び出しに変換します (Visual Basic) 句 GroupJoin します。