Queryable.ThenByDescending Method

定義

シーケンス内の後続の要素を降順で配置します。 Performs a subsequent ordering of the elements in a sequence in descending order.

オーバーロード

ThenByDescending<TSource,TKey>(IOrderedQueryable<TSource>, Expression<Func<TSource,TKey>>)

キーに従って、シーケンス内の後続の要素を降順で配置します。 Performs a subsequent ordering of the elements in a sequence in descending order, according to a key.

ThenByDescending<TSource,TKey>(IOrderedQueryable<TSource>, Expression<Func<TSource,TKey>>, IComparer<TKey>)

指定された比較子を使用して、シーケンス内の後続の要素を降順で配置します。 Performs a subsequent ordering of the elements in a sequence in descending order by using a specified comparer.

ThenByDescending<TSource,TKey>(IOrderedQueryable<TSource>, Expression<Func<TSource,TKey>>)

キーに従って、シーケンス内の後続の要素を降順で配置します。 Performs a subsequent ordering of the elements in a sequence in descending order, according to a key.

public static System.Linq.IOrderedQueryable<TSource> ThenByDescending<TSource,TKey> (this System.Linq.IOrderedQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,TKey>> keySelector);
型パラメーター
TSource

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

TKey

表された関数によって返されるキーの種類keySelectorします。 The type of the key returned by the function represented by keySelector.

パラメーター
source
IOrderedQueryable<TSource>

並べ替える要素を格納している IOrderedQueryable<T> An IOrderedQueryable<T> that contains elements to sort.

keySelector
Expression<Func<TSource,TKey>>

各要素からキーを抽出する関数。 A function to extract a key from each element.

戻り値

要素がキーに従って降順に並べ替えられている IOrderedQueryable<T> An IOrderedQueryable<T> whose elements are sorted in descending order according to a key.

例外

source または keySelectornull です。 source or keySelector is null.

注釈

このメソッドは、少なくとも 1 つのパラメーター型のExpression<TDelegate>型引数は、のいずれか、Func<T,TResult>型。This method has at least one parameter of type Expression<TDelegate> whose type argument is one of the Func<T,TResult> types. ラムダ式で、これらのパラメーターを渡すことができますにコンパイルされると、Expression<TDelegate>します。For these parameters, you can pass in a lambda expression and it will be compiled to an Expression<TDelegate>.

ThenByDescending<TSource,TKey>(IOrderedQueryable<TSource>, Expression<Func<TSource,TKey>>)メソッドを生成、MethodCallExpression呼び出しを表すThenByDescending<TSource,TKey>(IOrderedQueryable<TSource>, Expression<Func<TSource,TKey>>)として構築されたジェネリック メソッド自体。The ThenByDescending<TSource,TKey>(IOrderedQueryable<TSource>, Expression<Func<TSource,TKey>>) method generates a MethodCallExpression that represents calling ThenByDescending<TSource,TKey>(IOrderedQueryable<TSource>, Expression<Func<TSource,TKey>>) 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. 呼び出しの結果CreateQuery<TElement>(Expression)型にキャストはIOrderedQueryable<T>返されるとします。The result of calling CreateQuery<TElement>(Expression) is cast to type IOrderedQueryable<T> and returned.

呼び出し元を表す式ツリーを実行した結果として発生するクエリの動作ThenByDescending<TSource,TKey>(IOrderedQueryable<TSource>, Expression<Func<TSource,TKey>>)の型の実装によって異なります、sourceパラメーター。The query behavior that occurs as a result of executing an expression tree that represents calling ThenByDescending<TSource,TKey>(IOrderedQueryable<TSource>, Expression<Func<TSource,TKey>>) depends on the implementation of the type of the source parameter. 想定される動作は、2 番目の要素の並べ替えが実行されるsourceの降順で呼び出すことによって取得したキーに基づいたkeySelectorの各要素に対してsourceします。The expected behavior is that it performs a secondary sort of the elements of source in descending order, based on the key obtained by invoking keySelector on each element of source. すべて以前に確立した並べ替え順序は保持されます。All previously established sort orders are preserved.

ThenByDescending<TSource,TKey>(IOrderedQueryable<TSource>, Expression<Func<TSource,TKey>>, IComparer<TKey>)

指定された比較子を使用して、シーケンス内の後続の要素を降順で配置します。 Performs a subsequent ordering of the elements in a sequence in descending order by using a specified comparer.

public static System.Linq.IOrderedQueryable<TSource> ThenByDescending<TSource,TKey> (this System.Linq.IOrderedQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,TKey>> keySelector, System.Collections.Generic.IComparer<TKey> comparer);
型パラメーター
TSource

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

TKey

によって返されるキーの種類、 keySelector関数。 The type of the key that is returned by the keySelector function.

パラメーター
source
IOrderedQueryable<TSource>

並べ替える要素を格納している IOrderedQueryable<T> An IOrderedQueryable<T> that contains elements to sort.

keySelector
Expression<Func<TSource,TKey>>

各要素からキーを抽出する関数。 A function to extract a key from each element.

comparer
IComparer<TKey>

キーを比較する IComparer<T> An IComparer<T> to compare keys.

戻り値

要素がキーに従って降順に並べ替えられているコレクション。 A collection whose elements are sorted in descending order according to a key.

例外

sourcekeySelector、または comparer は、null です。 source or keySelector or comparer is null.

次のコード例は、使用する方法を示しますThenByDescending<TSource,TKey>(IOrderedQueryable<TSource>, Expression<Func<TSource,TKey>>, IComparer<TKey>)カスタム比較子を使用して、降順のシーケンス内の要素の 2 番目の並べ替えを実行します。The following code example demonstrates how to use ThenByDescending<TSource,TKey>(IOrderedQueryable<TSource>, Expression<Func<TSource,TKey>>, IComparer<TKey>) to perform a secondary ordering of the elements in a sequence in descending order by using a custom comparer.

public class CaseInsensitiveComparer : IComparer<string>
{
    public int Compare(string x, string y)
    {
        return string.Compare(x, y, true);
    }
}

public static void ThenByDescendingEx1()
{
    string[] fruits = 
    { "apPLe", "baNanA", "apple", "APple", "orange", "BAnana", "ORANGE", "apPLE" };

    // Sort the strings first ascending by their length and 
    // then descending using a custom case insensitive comparer.
    IEnumerable<string> query =
        fruits.AsQueryable()
        .OrderBy(fruit => fruit.Length)
        .ThenByDescending(fruit => fruit, new CaseInsensitiveComparer());

    foreach (string fruit in query)
        Console.WriteLine(fruit);
}

/*
    This code produces the following output:

    apPLe
    apple
    APple
    apPLE
    orange
    ORANGE
    baNanA
    BAnana
*/

Class CaseInsensitiveComparer
    Implements IComparer(Of String)

    Function Compare(ByVal x As String, ByVal y As String) As Integer _
        Implements IComparer(Of String).Compare

        ' Compare values and ignore case.
        Return String.Compare(x, y, True)
    End Function
End Class

Sub ThenByDescendingEx1()
    Dim fruits() As String = _
        {"apPLe", "baNanA", "apple", "APple", "orange", "BAnana", "ORANGE", "apPLE"}

    ' Sort the strings first ascending by their length and 
    ' then descending by using a custom case insensitive comparer.
    Dim query = fruits.AsQueryable() _
        .OrderBy(Function(fruit) fruit.Length) _
        .ThenByDescending(Function(fruit) fruit, New CaseInsensitiveComparer())

    Dim output As New System.Text.StringBuilder
    For Each fruit As String In query
        output.AppendLine(fruit)
    Next

    ' Display the results.
    MsgBox(output.ToString())
End Sub

' This code produces the following output:

' apPLe
' apple
' APple
' apPLE
' orange
' ORANGE
' baNanA
' BAnana

注釈

このメソッドは、少なくとも 1 つのパラメーター型のExpression<TDelegate>型引数は、のいずれか、Func<T,TResult>型。This method has at least one parameter of type Expression<TDelegate> whose type argument is one of the Func<T,TResult> types. ラムダ式で、これらのパラメーターを渡すことができますにコンパイルされると、Expression<TDelegate>します。For these parameters, you can pass in a lambda expression and it will be compiled to an Expression<TDelegate>.

ThenBy<TSource,TKey>(IOrderedQueryable<TSource>, Expression<Func<TSource,TKey>>, IComparer<TKey>)メソッドを生成、MethodCallExpression呼び出しを表すThenBy<TSource,TKey>(IOrderedQueryable<TSource>, Expression<Func<TSource,TKey>>, IComparer<TKey>)として構築されたジェネリック メソッド自体。The ThenBy<TSource,TKey>(IOrderedQueryable<TSource>, Expression<Func<TSource,TKey>>, IComparer<TKey>) method generates a MethodCallExpression that represents calling ThenBy<TSource,TKey>(IOrderedQueryable<TSource>, Expression<Func<TSource,TKey>>, IComparer<TKey>) 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. 呼び出しの結果CreateQuery<TElement>(Expression)型にキャストはIOrderedQueryable<T>返されるとします。The result of calling CreateQuery<TElement>(Expression) is cast to type IOrderedQueryable<T> and returned.

呼び出し元を表す式ツリーを実行した結果として発生するクエリの動作ThenBy<TSource,TKey>(IOrderedQueryable<TSource>, Expression<Func<TSource,TKey>>, IComparer<TKey>)の型の実装によって異なります、sourceパラメーター。The query behavior that occurs as a result of executing an expression tree that represents calling ThenBy<TSource,TKey>(IOrderedQueryable<TSource>, Expression<Func<TSource,TKey>>, IComparer<TKey>) depends on the implementation of the type of the source parameter. 想定される動作は、2 番目の要素の並べ替えが実行されるsourceの降順で呼び出すことによって取得したキーに基づいたkeySelectorの各要素に対してsourceします。The expected behavior is that it performs a secondary sort of the elements of source in descending order, based on the key obtained by invoking keySelector on each element of source. すべて以前に確立した並べ替え順序は保持されます。All previously established sort orders are preserved. comparerパラメーターを使用してキーの値を比較します。The comparer parameter is used to compare key values.

適用対象