Queryable.Distinct Method

定義

シーケンスから一意の要素を返します。 Returns distinct elements from a sequence.

オーバーロード

Distinct<TSource>(IQueryable<TSource>)

既定の等値比較子を使用して値を比較することにより、シーケンスから一意の要素を返します。 Returns distinct elements from a sequence by using the default equality comparer to compare values.

Distinct<TSource>(IQueryable<TSource>, IEqualityComparer<TSource>)

指定された IEqualityComparer<T> を使用して値を比較することにより、シーケンスから一意の要素を返します。 Returns distinct elements from a sequence by using a specified IEqualityComparer<T> to compare values.

Distinct<TSource>(IQueryable<TSource>)

既定の等値比較子を使用して値を比較することにより、シーケンスから一意の要素を返します。 Returns distinct elements from a sequence by using the default equality comparer to compare values.

public static System.Linq.IQueryable<TSource> Distinct<TSource> (this System.Linq.IQueryable<TSource> source);
型パラメーター
TSource

要素の型ソースします。 The type of the elements of source.

パラメーター
source
IQueryable<TSource>

重複を削除する対象の IQueryable<T> The IQueryable<T> to remove duplicates from.

戻り値
IQueryable<TSource>

source の一意の要素が格納される IQueryable<T> An IQueryable<T> that contains distinct elements from source.

例外

sourcenullです。 source is null.

次のコード例は、使用する方法を示しますDistinct<TSource>(IQueryable<TSource>)をシーケンスから一意の要素を返します。The following code example demonstrates how to use Distinct<TSource>(IQueryable<TSource>) to return distinct elements from a sequence.

List<int> ages = new List<int> { 21, 46, 46, 55, 17, 21, 55, 55 };

IEnumerable<int> distinctAges = ages.AsQueryable().Distinct();

Console.WriteLine("Distinct ages:");

foreach (int age in distinctAges)
    Console.WriteLine(age);

/*
    This code produces the following output:

    Distinct ages:
    21
    46
    55
    17
*/

Dim ages As List(Of Integer) = New List(Of Integer)(New Integer() {21, 46, 46, 55, 17, 21, 55, 55})

Dim distinctAges As IEnumerable(Of Integer) = ages.AsQueryable().Distinct()

Dim output As New System.Text.StringBuilder
output.AppendLine("Distinct ages:")

For Each age As Integer In distinctAges
    output.AppendLine(age)
Next

' Display the output.
MsgBox(output.ToString())

' This code produces the following output:
'
' Distinct(ages)
' 21
' 46
' 55
' 17

注釈

Distinct<TSource>(IQueryable<TSource>)メソッドを生成、MethodCallExpression呼び出しを表すDistinct<TSource>(IQueryable<TSource>)として構築されたジェネリック メソッド自体。The Distinct<TSource>(IQueryable<TSource>) method generates a MethodCallExpression that represents calling Distinct<TSource>(IQueryable<TSource>) itself as a constructed generic method. これは、後、渡します、MethodCallExpressionCreateQuery<TElement>(Expression)のメソッド、IQueryProviderによって表される、Providerのプロパティ、sourceパラメーター。It then passes the MethodCallExpression to the CreateQuery<TElement>(Expression) method of the IQueryProvider represented by the Provider property of the source parameter.

呼び出し元を表す式ツリーを実行した結果として発生するクエリの動作Distinct<TSource>(IQueryable<TSource>)の型の実装によって異なります、sourceパラメーター。The query behavior that occurs as a result of executing an expression tree that represents calling Distinct<TSource>(IQueryable<TSource>) depends on the implementation of the type of the source parameter. 想定される動作は一意の項目の順序なしのシーケンスが返されるsourceします。The expected behavior is that it returns an unordered sequence of the unique items in source.

Distinct<TSource>(IQueryable<TSource>, IEqualityComparer<TSource>)

指定された IEqualityComparer<T> を使用して値を比較することにより、シーケンスから一意の要素を返します。 Returns distinct elements from a sequence by using a specified IEqualityComparer<T> to compare values.

public static System.Linq.IQueryable<TSource> Distinct<TSource> (this System.Linq.IQueryable<TSource> source, System.Collections.Generic.IEqualityComparer<TSource> comparer);
型パラメーター
TSource

要素の型ソースします。 The type of the elements of source.

パラメーター
source
IQueryable<TSource>

重複を削除する対象の IQueryable<T> The IQueryable<T> to remove duplicates from.

comparer
IEqualityComparer<TSource>

値を比較する IEqualityComparer<T> An IEqualityComparer<T> to compare values.

戻り値
IQueryable<TSource>

source の一意の要素が格納される IQueryable<T> An IQueryable<T> that contains distinct elements from source.

例外

source または comparernull です。 source or comparer is null.

注釈

Distinct<TSource>(IQueryable<TSource>, IEqualityComparer<TSource>)メソッドを生成、MethodCallExpression呼び出しを表すDistinct<TSource>(IQueryable<TSource>, IEqualityComparer<TSource>)として構築されたジェネリック メソッド自体。The Distinct<TSource>(IQueryable<TSource>, IEqualityComparer<TSource>) method generates a MethodCallExpression that represents calling Distinct<TSource>(IQueryable<TSource>, IEqualityComparer<TSource>) itself as a constructed generic method. これは、後、渡します、MethodCallExpressionCreateQuery<TElement>(Expression)のメソッド、IQueryProviderによって表される、Providerのプロパティ、sourceパラメーター。It then passes the MethodCallExpression to the CreateQuery<TElement>(Expression) method of the IQueryProvider represented by the Provider property of the source parameter.

呼び出し元を表す式ツリーを実行した結果として発生するクエリの動作Distinct<TSource>(IQueryable<TSource>, IEqualityComparer<TSource>)の型の実装によって異なります、sourceパラメーター。The query behavior that occurs as a result of executing an expression tree that represents calling Distinct<TSource>(IQueryable<TSource>, IEqualityComparer<TSource>) depends on the implementation of the type of the source parameter. 想定される動作は一意の項目の順序なしのシーケンスが返されるsourceを使用してcomparer値を比較します。The expected behavior is that it returns an unordered sequence of the unique items in source by using comparer to compare values.

適用対象