DataTableReader.GetValues(Object[]) Methode

Definition

Füllt ein Array von Objekten mit den Spaltenwerten der aktuellen Zeile auf.Populates an array of objects with the column values of the current row.

public:
 override int GetValues(cli::array <System::Object ^> ^ values);
public override int GetValues (object[] values);
override this.GetValues : obj[] -> int
Public Overrides Function GetValues (values As Object()) As Integer

Parameter

values
Object[]

Ein Array vom Typ Object, in das die Spaltenwerte aus dem DataTableReader kopiert werden sollen.An array of Object into which to copy the column values from the DataTableReader.

Gibt zurück

Die Anzahl der in das Array kopierten Spaltenwerte.The number of column values copied into the array.

Ausnahmen

Der übergebene Index lag außerhalb des Bereichs von 0 bis FieldCount -1.The index passed was outside the range of 0 to FieldCount - 1.

Es wurde versucht, Daten aus einer gelöschten Zeile abzurufen.An attempt was made to retrieve data from a deleted row.

Es wurde versucht, eine Spalte in einem geschlossenen DataTableReader zu lesen oder auf sie zuzugreifen.An attempt was made to read or access a column in a closed DataTableReader .

Beispiele

Im folgenden Beispiel wird veranschaulicht, wie ein Array mit der richtigen Größe verwendet wird, um alle Werte aus der aktuellen Zeile in der angegebenen DataTableReaderzu lesen.The following example demonstrates using an array that is the correct size, to read all values from the current row in the supplied DataTableReader. Außerdem veranschaulicht das Beispiel die Verwendung eines Arrays mit fester Größe, das entweder kleiner oder größer als die Anzahl der verfügbaren Spalten sein könnte.In addition, the sample demonstrates using a fixed-sized array that could be either smaller or larger than the number of available columns.

private static void TestGetValues(DataTableReader reader)
{
    // Given a DataTableReader, use the GetValues
    // method to retrieve a full row of data.
    // Test the GetValues method, passing in an array large
    // enough for all the columns.
    Object[] values = new Object[reader.FieldCount];
    int fieldCount = reader.GetValues(values);

    Console.WriteLine("reader.GetValues retrieved {0} columns.",
        fieldCount);
    for (int i = 0; i < fieldCount; i++)
        Console.WriteLine(values[i]);

    Console.WriteLine();

    // Now repeat, using an array that may contain a different 
    // number of columns than the original data. This should work correctly,
    // whether the size of the array is larger or smaller than 
    // the number of columns.

    // Attempt to retrieve three columns of data.
    values = new Object[3];
    fieldCount = reader.GetValues(values);
    Console.WriteLine("reader.GetValues retrieved {0} columns.",
        fieldCount);
    for (int i = 0; i < fieldCount; i++)
        Console.WriteLine(values[i]);
}
Private Sub TestGetValues(ByVal reader As DataTableReader)

    ' Given a DataTableReader, use the GetValues
    ' method to retrieve a full row of data.

    ' Test the GetValues method, passing in an array large
    ' enough for all the columns.
    Dim values(reader.FieldCount - 1) As Object
    Dim fieldCount As Integer = reader.GetValues(values)
    Console.WriteLine("reader.GetValues retrieved {0} columns.", _
         fieldCount)
    For i As Integer = 0 To fieldCount - 1
        Console.WriteLine(values(i))
    Next

    Console.WriteLine()

    ' Now repeat, using an array that may contain a different 
    ' number of columns than the original data. This should work correctly,
    ' whether the size of the array is larger or smaller than 
    ' the number of columns.

    ' Attempt to retrieve three columns of data.
    ReDim values(2)
    fieldCount = reader.GetValues(values)
    Console.WriteLine("reader.GetValues retrieved {0} columns.", _
         fieldCount)
    For i As Integer = 0 To fieldCount - 1
        Console.WriteLine(values(i))
    Next
End Sub

Hinweise

Bei den meisten Anwendungen bietet diese Methode eine effiziente Möglichkeit zum Abrufen aller Spalten, anstatt jede Spalte einzeln abzurufen.For most applications, this method provides an efficient means for retrieving all columns, instead of retrieving each column individually. Wenn Sie alle Spaltenwerte aus einer Zeile innerhalb des DataTableReaderabrufen möchten, bietet die GetValues-Methode die effizienteste Lösung.If your intent is to retrieve all the column values from a row within the DataTableReader, the GetValues method provides the most efficient solution.

Sie können ein Object Array übergeben, das weniger als die Anzahl der Spalten enthält, die in der resultierenden Zeile enthalten sind.You can pass an Object array that contains fewer than the number of columns that are contained in the resulting row. Nur die Datenmenge, die das Object Array aufnehmen kann, wird in das Array kopiert.Only the amount of data the Object array can hold is copied to the array. Sie können auch ein Object Array übergeben, dessen Länge größer ist als die Anzahl der Spalten, die in der resultierenden Zeile enthalten sind. in diesem Fall bleiben die zusätzlichen Array Elemente durch den Methodenaufrufe unverändert.You can also pass an Object array whose length is more than the number of columns that are contained in the resulting row, in which case the additional array elements remains unchanged by the method call.

Diese Methode platziert DBNull im Ausgabe Array für NULL-Spalten.This method places DBNull in the output array for null columns.

Gilt für: