次の方法で共有


DataRow.AcceptChanges メソッド

定義

前回 AcceptChanges() を呼び出した以降にこの行に対して行われたすべての変更をコミットします。

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

例外

行がこのテーブルに属していません。

次の例では、最初に 1 つの列で新しい DataTable を作成し、次に 1 つの DataRowを作成します。 DataRowが作成、追加、変更、および削除されると、その RowState が印刷されます。

private void DemonstrateAcceptChanges()
{
    //Run a function to create a DataTable with one column.
    DataTable table = MakeTable();
    DataRow row;

    // Create a new DataRow.
    row = table.NewRow();
    // Detached row.
    Console.WriteLine("New Row " + row.RowState);

    table.Rows.Add(row);
    // New row.
    Console.WriteLine("AddRow " + row.RowState);

    table.AcceptChanges();
    // Unchanged row.
    Console.WriteLine("AcceptChanges " + row.RowState);

    row["FirstName"] = "Scott";
    // Modified row.
    Console.WriteLine("Modified " + row.RowState);

    row.Delete();
    // Deleted row.
    Console.WriteLine("Deleted " + row.RowState);
}

private DataTable MakeTable()
{
    // Make a simple table with one column.
    DataTable table = new DataTable("table");
    DataColumn fnameColumn = new DataColumn(
        "FirstName", Type.GetType("System.String"));
    table.Columns.Add(fnameColumn);
    return table;
}
Private Sub DemonstrateAcceptChanges()
    ' Run a function to create a DataTable with one column.
    Dim table As DataTable = MakeTable()
    Dim row As DataRow 
 
    ' Create a new DataRow.
    row = table.NewRow()
    ' Detached row.
    Console.WriteLine("New Row " & row.RowState)
 
    table.Rows.Add(row)
    ' New row.
    Console.WriteLine("AddRow " & row.RowState)
 
    table.AcceptChanges()
    ' Unchanged row.
    Console.WriteLine("AcceptChanges " & row.RowState)
 
    row("FirstName") = "Scott"
    ' Modified row.
    Console.WriteLine("Modified " & row.RowState)
 
    row.Delete()
    ' Deleted row.
    Console.WriteLine("Deleted " & row.RowState)
 End Sub
 
 Private Function MakeTable()As DataTable
    ' Make a simple table with one column.
    Dim table As New DataTable("table")
    Dim fnameColumn As New DataColumn( _
        "FirstName", Type.GetType("System.String"))
    table.Columns.Add(fnameColumn)
    MakeTable = table
 End Function

注釈

AcceptChanges呼び出すと、 EndEdit メソッドが暗黙的に呼び出され、編集が終了します。 行の が RowState [追加] または [変更済み] の場合、 RowState は [変更なし] になります。 が RowState [削除済み] の場合、行は削除されます。

詳細については、 BeginEdit メソッドを参照してください。

DataTableクラスには、テーブル全体にAcceptChanges加えられた変更に影響を与える メソッドもあります。 個々のデータ行に対する変更を受け入れる方法と拒否する方法を示すコード例の詳細については、「 AcceptChanges と RejectChanges」を参照してください。

適用対象

こちらもご覧ください