DataRow.BeginEdit Method

Definition

Spustí operaci Edit pro objekt DataRow.Starts an edit operation on a DataRow object.

public:
 void BeginEdit();
public void BeginEdit ();
member this.BeginEdit : unit -> unit
Public Sub BeginEdit ()

Exceptions

Metoda byla volána uvnitř události RowChanging.The method was called inside the RowChanging event.

Metoda byla volána na odstraněný řádek.The method was called upon a deleted row.

Examples

Příklad vytvoří jednoduchý DataTable s jedním DataColumn a pěti objekty DataRow a UniqueConstraint.The example creates a simple DataTable with one DataColumn and five DataRow objects, and a UniqueConstraint. K monitorování je také přidána obslužná rutina události RowChanged, když je hodnota řádku měněna.A RowChanged event handler is also added to monitor when the row's value is changing. Po vyvolání BeginEdit na stávajících řádcích je omezení a událost dočasně zakázané a vytisknou se původní a navrhované hodnoty.After invoking BeginEdit on the existing rows, the constraint and event are temporarily disabled and the original and proposed values are printed. Znovu se vyvolala BeginEdit pro nastavení dvou řádků na stejnou hodnotu.The BeginEdit is again invoked to set two rows to the same value. Při volání EndEdit se u stejných hodnot UniqueConstraint vynutilo.When EndEdit is called, the UniqueConstraint is enforced on the identical values.

private void DemonstrateRowBeginEdit()
{
    DataTable table = new DataTable("table1");
    DataColumn column = new
        DataColumn("col1",Type.GetType("System.Int32"));
    table.RowChanged+=new
        DataRowChangeEventHandler(Row_Changed);
    table.Columns.Add(column);

    // Add a UniqueConstraint to the table.
    table.Constraints.Add(new UniqueConstraint(column));

    // Add five rows.
    DataRow newRow;

    for(int i = 0;i<5; i++)
    {
        // RowChanged event will occur for every addition.
        newRow= table.NewRow();
        newRow[0]= i;
        table.Rows.Add(newRow);
    }
    // AcceptChanges.
    table.AcceptChanges();

    // Invoke BeginEdit on each.
    Console.WriteLine(
        "\n Begin Edit and print original and proposed values \n");
    foreach(DataRow row in table.Rows)
    {

        row.BeginEdit();
        row[0]=(int) row[0]+10;
        Console.Write("\table Original \table" +
            row[0, DataRowVersion.Original]);
        Console.Write("\table Proposed \table" +
            row[0,DataRowVersion.Proposed] + "\n");
    }
    Console.WriteLine("\n");
    // Accept changes
    table.AcceptChanges();
    // Change two rows to identical values after invoking BeginEdit.
    table.Rows[0].BeginEdit();
    table.Rows[1].BeginEdit();
    table.Rows[0][0]= 100;
    table.Rows[1][0]=100;
    try
    {
        /* Now invoke EndEdit. This will cause the UniqueConstraint
           to be enforced.*/
        table.Rows[0].EndEdit();
        table.Rows[1].EndEdit();
    }
    catch(Exception e)
    {
        // Process exception and return.
        Console.WriteLine("Exception of type {0} occurred.",
            e.GetType());
    }
}

private void Row_Changed(object sender,
    System.Data.DataRowChangeEventArgs e)
{
    DataTable table = (DataTable)  sender;
    Console.WriteLine("RowChanged " + e.Action.ToString()
        + "\table" + e.Row.ItemArray[0]);
}
Private Sub DemonstrateRowBeginEdit()
    Dim table As New DataTable("table1")
    Dim column As New DataColumn("col1", Type.GetType("System.Int32"))
    AddHandler table.RowChanged, AddressOf Row_Changed
    table.Columns.Add(column)

    ' Add a UniqueConstraint to the table.
    table.Constraints.Add(New UniqueConstraint(column))

    ' Add five rows.
    Dim newRow As DataRow
       
    Dim i As Integer
    For i = 0 To 4
        ' RowChanged event will occur for every addition.
        newRow = table.NewRow()
        newRow(0) = i
        table.Rows.Add(newRow)
    Next i

    ' AcceptChanges.
    table.AcceptChanges()

    ' Invoke BeginEdit on each.
    Console.WriteLine(ControlChars.Cr _
       & " Begin Edit and print original and proposed values " _
       & ControlChars.Cr)
    Dim row As DataRow
    For Each row In  table.Rows           
        row.BeginEdit()
        row(0) = CInt(row(0)) & 10
        Console.Write(ControlChars.Tab & " Original " & ControlChars.Tab _
           & row(0, DataRowVersion.Original).ToString())
        Console.Write(ControlChars.Tab & " Proposed " & ControlChars.Tab _
           & row(0, DataRowVersion.Proposed).ToString() & ControlChars.Cr)
    Next row
    Console.WriteLine(ControlChars.Cr)

    ' Accept changes
    table.AcceptChanges()

    ' Change two rows to identical values after invoking BeginEdit.
    table.Rows(0).BeginEdit()
    table.Rows(1).BeginEdit()
    table.Rows(0)(0) = 100
    table.Rows(1)(0) = 100
    Try
        ' Now invoke EndEdit. This will cause the UniqueConstraint
        ' to be enforced.
        table.Rows(0).EndEdit()
        table.Rows(1).EndEdit()
    Catch e As Exception
    ' Process exception and return.
        Console.WriteLine("Exception of type {0} occurred.", _
           e.GetType().ToString())
    End Try
End Sub

Private Sub Row_Changed _
(sender As Object, e As System.Data.DataRowChangeEventArgs)
    Dim table As DataTable = CType(sender, DataTable)
    Console.WriteLine("RowChanged " & e.Action.ToString() _
       & ControlChars.Tab & e.Row.ItemArray(0).ToString())
End Sub

Remarks

K přepnutí DataRow do režimu úprav použijte metodu BeginEdit.Use the BeginEdit method to put a DataRow into edit mode. V tomto režimu jsou události dočasně pozastaveny, takže uživatel může provádět změny ve více než jednom řádku bez aktivace ověřovacích pravidel.In this mode, events are temporarily suspended, letting the user make changes to more than one row without triggering validation rules. Pokud třeba chcete zajistit, aby se hodnota sloupce pro celkovou částku rovnala hodnotám pro sloupce debetu a kreditu na řádku, můžete každý řádek vložit do režimu úprav, abyste mohli pozastavit ověřování hodnot řádků, dokud se uživatel pokusí hodnoty potvrdit.For example, if you must make sure that the value of the column for a total amount is equal to the values for the debit and credit columns in a row, you can put each row into edit mode to suspend the validation of the row values until the user tries to commit the values.

Metoda BeginEdit je volána implicitně, když uživatel změní hodnotu ovládacího prvku vázaného na data; Metoda EndEdit je volána implicitně při vyvolání metody AcceptChanges objektu DataTable.The BeginEdit method is called implicitly when the user changes the value of a data-bound control; the EndEdit method is called implicitly when you invoke the AcceptChanges method for the DataTable object. V tomto režimu úprav DataRow ukládá reprezentace původní a nové navržené hodnoty.While in this edit mode, the DataRow stores representations of the original and new proposed values. Proto dokud není volána metoda EndEdit, můžete načíst původní nebo navrhovanou verzi předáním buď DataRowVersion.Original nebo DataRowVersion.Proposed pro parametr version vlastnosti Item[].Therefore, as long as the EndEdit method has not been called, you can retrieve either the original or proposed version by passing either DataRowVersion.Original or DataRowVersion.Proposed for the version parameter of the Item[] property. V tomto okamžiku můžete také všechny úpravy zrušit vyvoláním metody CancelEdit.You can also cancel any edits at this point by invoking the CancelEdit method.

Chcete-li zjistit, zda řádek obsahuje původní nebo navrhovanou hodnotu, zavolejte metodu HasVersion.To see if the row contains an original or proposed value, call the HasVersion method.

Note

Metoda BeginEdit dočasně pozastaví RowChanging události, ale operace delete nikoli.The BeginEdit method temporarily suspends RowChanging events, but the delete operation does not.

Applies to

See also