DataRow.ItemArray Eigenschap

Definitie

Hiermee haalt u alle waarden voor deze rij op of stelt u deze in via een matrix.

public:
 property cli::array <System::Object ^> ^ ItemArray { cli::array <System::Object ^> ^ get(); void set(cli::array <System::Object ^> ^ value); };
public object[] ItemArray { get; set; }
member this.ItemArray : obj[] with get, set
Public Property ItemArray As Object()

Waarde van eigenschap

Object[]

Een matrix van het type Object.

Uitzonderingen

De matrix is groter dan het aantal kolommen in de tabel.

Een waarde in de matrix komt niet overeen met DataType de waarde in de desbetreffende DataColumnwaarde.

Een bewerking heeft een beperking verbroken.

Een bewerking heeft geprobeerd de waarde van een alleen-lezen kolom te wijzigen.

Een bewerking heeft geprobeerd een null-waarde in een kolom te plaatsen waarin AllowDBNull het DataColumn object zich bevindt false.

De rij is verwijderd.

Voorbeelden

In de volgende voorbeelden ziet u hoe u waarden kunt ophalen en instellen met behulp van de ItemArray eigenschap.

private void CreateRowsWithItemArray()
{
    // Make a DataTable using the function below.
    DataTable dt = MakeTableWithAutoIncrement();
    DataRow relation;
    // Declare the array variable.
    object [] rowArray = new object[2];
    // Create 10 new rows and add to DataRowCollection.
    for(int i = 0; i <10; i++)
    {
        rowArray[0]=null;
        rowArray[1]= "item " + i;
        relation = dt.NewRow();
        relation.ItemArray = rowArray;
        dt.Rows.Add(relation);
    }
    PrintTable(dt);
}

private DataTable MakeTableWithAutoIncrement()
{
    // Make a table with one AutoIncrement column.
    DataTable table = new DataTable("table");
    DataColumn idColumn = new DataColumn("id",
        Type.GetType("System.Int32"));
    idColumn.AutoIncrement = true;
    idColumn.AutoIncrementSeed = 10;
    table.Columns.Add(idColumn);

    DataColumn firstNameColumn = new DataColumn("Item",
        Type.GetType("System.String"));
    table.Columns.Add(firstNameColumn);
    return table;
}

private void PrintTable(DataTable table)
{
    foreach(DataRow row in table.Rows)
    {
        foreach(DataColumn column in table.Columns)
        {
            Console.WriteLine(row[column]);
        }
    }
}
Private Sub CreateRowsWithItemArray()
    ' Make a DataTable using the function below.
    Dim dt As DataTable = MakeTableWithAutoIncrement()
    Dim relation As DataRow

    ' Declare the array variable.
    Dim rowArray(1) As Object

    ' Create 10 new rows and add to DataRowCollection.
    Dim i As Integer
    For i = 0 to 9
       rowArray(0) = DBNull.Value
       rowArray(1)= "item " & i.ToString()
       relation = dt.NewRow()
       relation.ItemArray = rowArray
       dt.Rows.Add(relation)
    Next
    PrintTable(dt)
End Sub
 
Private Function MakeTableWithAutoIncrement() As DataTable
    ' Make a table with one AutoIncrement column.
    Dim table As New DataTable("table")
    Dim idColumn As New DataColumn("id", _
        Type.GetType("System.Int32"))
    idColumn.AutoIncrement = True
    idColumn.AutoIncrementSeed = 10
    table.Columns.Add (idColumn)
    
    Dim firstNameColumn As New DataColumn( _
        "Item", Type.GetType("System.String"))
    table.Columns.Add(firstNameColumn)
    MakeTableWithAutoIncrement = table
End Function
 
Private Sub PrintTable(table As DataTable)
    Dim row As DataRow
    Dim column As DataColumn
    For Each row in table.Rows
       For Each column in table.Columns
          Console.WriteLine(row(column))
       Next
    Next
End Sub

Opmerkingen

U kunt deze eigenschap gebruiken om waarden voor deze rij in te stellen of op te halen via een matrix. Als u deze eigenschap gebruikt om waarden in te stellen, moet de matrix dezelfde grootte hebben en dezelfde volgorde hebben als de kolomverzameling. Doorgeven null in de ItemArray geeft aan dat er geen waarde is opgegeven.

Gebruikers kunnen uitzonderingen genereren in de ColumnChanging gebeurtenis of de RowChanging gebeurtenis.

Van toepassing op

Zie ook