次の方法で共有


Take 句 (Visual Basic)

更新 : 2007 年 11 月

コレクションの先頭から、指定された数の連続する要素を返します。

Take count

指定項目

  • count
    必ず指定します。値、または返される連続する要素の数に評価される式。

解説

Take 句を使用すると、結果リストの先頭から取得された、指定した数の連続する要素がクエリに含まれます。含まれる要素の数は、count パラメータによって指定されます。

Take 句をSkip 句と一緒に使用して、クエリの任意の部分の範囲のデータを返すことができます。これを行うには、範囲の先頭となる要素のインデックスを Skip 句に渡し、範囲のサイズを Take 句に渡します。この場合、Take 句は、Skip 句の後ろに指定する必要があります。

クエリで Take 句を使用するときは、Take 句によって目的の結果を取得することが可能な順序で結果が返されることを確認する必要があります。クエリ結果の順序の詳細については、「Order By 句 (Visual Basic)」を参照してください。

TakeWhile 句を使用して、指定した条件に応じた特定の要素だけが返されるように指定できます。

使用例

次のコード例では、Take 句を Skip 句と一緒に使用して、ページのクエリからデータを返します。GetCustomers 関数は、Skip 句を使用して、指定された開始インデックス値までリストの顧客をバイパスし、Take 句を使用して、そのインデックス値から始まる顧客のページを返します。

Public Sub PagingSample()
  Dim pageNumber As Integer = 0
  Dim pageSize As Integer = 10

  Dim customersPage = GetCustomers(pageNumber * pageSize, pageSize)

  Do While customersPage IsNot Nothing
    Console.WriteLine(vbCrLf & "Page: " & pageNumber + 1 & vbCrLf)

    For Each cust In customersPage
      Console.WriteLine(cust.CustomerID & ", " & cust.CompanyName)
    Next

    Console.WriteLine(vbCrLf)

    pageNumber += 1
    customersPage = GetCustomers(pageNumber * pageSize, pageSize)
  Loop
End Sub

Public Function GetCustomers(ByVal startIndex As Integer, _
                             ByVal pageSize As Integer) As List(Of Customer)

  Dim customers = GetCustomerList()

  Dim returnCustomers = From cust In customers _
                        Skip startIndex Take pageSize

  If returnCustomers.Count = 0 Then Return Nothing

  Return returnCustomers
End Function

参照

概念

Visual Basic における LINQ の概要

参照

Select 句 (Visual Basic)

From 句 (Visual Basic)

Order By 句 (Visual Basic)

Take While 句 (Visual Basic)

Skip 句 (Visual Basic)

その他の技術情報

クエリ (Visual Basic)