Enumerable.GroupJoin メソッド
定義
重要
一部の情報は、リリース前に大きく変更される可能性があるプレリリースされた製品に関するものです。 Microsoft は、ここに記載されている情報について、明示または黙示を問わず、一切保証しません。
キーの等価性に基づいて 2 つのシーケンスの要素を関連付け、結果をグループ化します。
オーバーロード
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>) |
キーの等価性に基づいて 2 つのシーケンスの要素を関連付け、結果をグループ化します。 キーの比較には、指定した IEqualityComparer<T> が使用されます。 |
GroupJoin<TOuter,TInner,TKey,TResult>(IEnumerable<TOuter>, IEnumerable<TInner>, Func<TOuter,TKey>, Func<TInner,TKey>, Func<TOuter,IEnumerable<TInner>, TResult>)
- ソース:
- GroupJoin.cs
- ソース:
- GroupJoin.cs
- ソース:
- GroupJoin.cs
キーの等価性に基づいて 2 つのシーケンスの要素を関連付け、結果をグループ化します。 キーの比較には、既定の等値比較子が使用されます。
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
最初のシーケンスの要素の型。
- TInner
2 番目のシーケンスの要素の型。
- TKey
キー セレクター関数によって返されるキーの型。
- TResult
結果要素の型。
パラメーター
- outer
- IEnumerable<TOuter>
結合する最初のシーケンス。
- inner
- IEnumerable<TInner>
最初のシーケンスに結合するシーケンス。
- outerKeySelector
- Func<TOuter,TKey>
最初のシーケンスの各要素から結合キーを抽出する関数。
- innerKeySelector
- Func<TInner,TKey>
2 番目のシーケンスの各要素から結合キーを抽出する関数。
- resultSelector
- Func<TOuter,IEnumerable<TInner>,TResult>
最初のシーケンスの要素から結果要素を作成し、2 番目のシーケンスから一致する要素のコレクションを作成する関数。
戻り値
2 つのシーケンスでグループ化結合を実行することによって取得される TResult
型の要素を含む IEnumerable<T>。
例外
outer
、inner
、outerKeySelector
、innerKeySelector
、または resultSelector
が null
。
例
次のコード例では、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) =>
new
{
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)
Next
Next
' 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
メソッドを直接呼び出すか、C# で foreach
を使用するか、Visual Basic で For Each
を使用してオブジェクトが列挙されるまで実行されません。
既定の等値比較子 (Default) は、キーのハッシュと比較に使用されます。
GroupJoin は階層的な結果を生成します。つまり、outer
の要素は、inner
の一致する要素のコレクションとペアになります。
GroupJoin
を使用すると、outer
の各要素の一致のセット全体に基づいて結果を作成できます。
手記
outer
の特定の要素に対して inner
に関連付けられた要素がない場合、その要素の一致のシーケンスは空になりますが、結果には引き続き表示されます。
resultSelector
関数は、outer
要素ごとに 1 回だけ呼び出され、outer
要素と一致するすべての inner
要素のコレクションが呼び出されます。 これは、Join メソッドとは異なり、結果セレクター関数は、outer
の 1 つの要素と inner
の 1 つの要素を含むペアで呼び出されます。
GroupJoin
は、outer
の要素の順序を保持し、outer
の各要素に対して、inner
からの一致する要素の順序を保持します。
GroupJoin には、従来のリレーショナル データベースの用語に直接相当するものはありません。 ただし、このメソッドは内部結合と左外部結合のスーパーセットを実装します。 これらの操作はどちらも、グループ化結合の観点から記述できます。 詳細については、「結合操作」を参照してください。
クエリ式の構文では、join ... into
(C#) 句または Group Join
(Visual Basic) 句が GroupJoinの呼び出しに変換されます。
こちらもご覧ください
適用対象
GroupJoin<TOuter,TInner,TKey,TResult>(IEnumerable<TOuter>, IEnumerable<TInner>, Func<TOuter,TKey>, Func<TInner,TKey>, Func<TOuter,IEnumerable<TInner>, TResult>, IEqualityComparer<TKey>)
- ソース:
- GroupJoin.cs
- ソース:
- GroupJoin.cs
- ソース:
- GroupJoin.cs
キーの等価性に基づいて 2 つのシーケンスの要素を関連付け、結果をグループ化します。 キーの比較には、指定した IEqualityComparer<T> が使用されます。
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
最初のシーケンスの要素の型。
- TInner
2 番目のシーケンスの要素の型。
- TKey
キー セレクター関数によって返されるキーの型。
- TResult
結果要素の型。
パラメーター
- outer
- IEnumerable<TOuter>
結合する最初のシーケンス。
- inner
- IEnumerable<TInner>
最初のシーケンスに結合するシーケンス。
- outerKeySelector
- Func<TOuter,TKey>
最初のシーケンスの各要素から結合キーを抽出する関数。
- innerKeySelector
- Func<TInner,TKey>
2 番目のシーケンスの各要素から結合キーを抽出する関数。
- resultSelector
- Func<TOuter,IEnumerable<TInner>,TResult>
最初のシーケンスの要素から結果要素を作成し、2 番目のシーケンスから一致する要素のコレクションを作成する関数。
- comparer
- IEqualityComparer<TKey>
キーのハッシュと比較を行う IEqualityComparer<T>。
戻り値
2 つのシーケンスでグループ化結合を実行することによって取得される TResult
型の要素を含む IEnumerable<T>。
例外
outer
、inner
、outerKeySelector
、innerKeySelector
、または resultSelector
が null
。
注釈
このメソッドは、遅延実行を使用して実装されます。 即時戻り値は、アクションの実行に必要なすべての情報を格納するオブジェクトです。 このメソッドで表されるクエリは、GetEnumerator
メソッドを直接呼び出すか、C# で foreach
を使用するか、Visual Basic で For Each
を使用してオブジェクトが列挙されるまで実行されません。
comparer
が null
の場合、キーのハッシュと比較には、既定の等値比較子 (Default) が使用されます。
GroupJoin は階層的な結果を生成します。つまり、outer
の要素は、inner
の一致する要素のコレクションとペアになります。
GroupJoin
を使用すると、outer
の各要素の一致のセット全体に基づいて結果を作成できます。
手記
outer
の特定の要素に対して inner
に関連付けられた要素がない場合、その要素の一致のシーケンスは空になりますが、結果には引き続き表示されます。
resultSelector
関数は、outer
要素ごとに 1 回だけ呼び出され、outer
要素と一致するすべての inner
要素のコレクションが呼び出されます。 これは、outer
の 1 つの要素と inner
の 1 つの要素を含むペアで結果セレクター関数が呼び出される Join メソッドとは異なります。
GroupJoin
は、outer
の要素の順序を保持し、outer
の各要素に対して、inner
からの一致する要素の順序を保持します。
GroupJoin には、従来のリレーショナル データベースの用語に直接相当するものはありません。 ただし、このメソッドは内部結合と左外部結合のスーパーセットを実装します。 これらの操作はどちらも、グループ化結合の観点から記述できます。 詳細については、「結合操作」を参照してください。
こちらもご覧ください
適用対象
.NET