DataTable.Merge Methode

Definition

Führen Sie die angegebene DataTable mit der aktuellen DataTable zusammen.Merge the specified DataTable with the current DataTable.

Überlädt

Merge(DataTable, Boolean, MissingSchemaAction)

Führen Sie die angegebene DataTable mit der aktuellen DataTable zusammen, und geben Sie an, ob die Änderungen in der aktuellen DataTable beibehalten werden sollen und wie das fehlende Schema behandelt werden soll.Merge the specified DataTable with the current DataTable, indicating whether to preserve changes and how to handle missing schema in the current DataTable.

Merge(DataTable, Boolean)

Führen Sie die angegebene DataTable mit der aktuellen DataTable zusammen, und geben Sie an, ob die Änderungen in der aktuellen DataTable beibehalten werden sollen.Merge the specified DataTable with the current DataTable, indicating whether to preserve changes in the current DataTable.

Merge(DataTable)

Führen Sie die angegebene DataTable mit der aktuellen DataTable zusammen.Merge the specified DataTable with the current DataTable.

Beispiele

In der folgenden Konsolenanwendung wird das Verhalten missingSchemaAction des-Parameters Merge der-Methode veranschaulicht.The following console application demonstrates the behavior of the missingSchemaAction parameter of the Merge method. In diesem Beispiel werden zwei Versionen derselben Tabelle erstellt, wobei das Schema für die zweite Version geändert wird.This example creates two versions of the same table, modifying the schema for the second version. Der Code versucht dann, die zweite Tabelle mit der ersten zu verbinden.The code then attempts to merge the second table into the first.

Hinweis

Dieses Beispiel zeigt, wie eine der überladenen Versionen von Merge verwendet werden kann.This example shows how to use one of the overloaded versions of Merge. Weitere Beispiele, die möglicherweise verfügbar sind, finden Sie in den Themen zu den einzelnen Überladungen.For other examples that might be available, see the individual overload topics.

private static void DemonstrateMergeTable()
{
    DataTable table1 = new DataTable("Items");

    // Add columns
    DataColumn idColumn = new DataColumn("id", typeof(System.Int32));
    DataColumn itemColumn = new DataColumn("item", typeof(System.Int32));
    table1.Columns.Add(idColumn);
    table1.Columns.Add(itemColumn);

    // Set the primary key column.
    table1.PrimaryKey = new DataColumn[] { idColumn };

    // Add RowChanged event handler for the table.
    table1.RowChanged += new 
        System.Data.DataRowChangeEventHandler(Row_Changed);

    // Add ten rows.
    DataRow row;
    for (int i = 0; i <= 9; i++)
    {
        row = table1.NewRow();
        row["id"] = i;
        row["item"] = i;
        table1.Rows.Add(row);
    }

    // Accept changes.
    table1.AcceptChanges();
    PrintValues(table1, "Original values");

    // Create a second DataTable identical to the first.
    DataTable table2 = table1.Clone();

    // Add column to the second column, so that the 
    // schemas no longer match.
    table2.Columns.Add("newColumn", typeof(System.String));

    // Add three rows. Note that the id column can't be the 
    // same as existing rows in the original table.
    row = table2.NewRow();
    row["id"] = 14;
    row["item"] = 774;
    row["newColumn"] = "new column 1";
    table2.Rows.Add(row);

    row = table2.NewRow();
    row["id"] = 12;
    row["item"] = 555;
    row["newColumn"] = "new column 2";
    table2.Rows.Add(row);

    row = table2.NewRow();
    row["id"] = 13;
    row["item"] = 665;
    row["newColumn"] = "new column 3";
    table2.Rows.Add(row);

    // Merge table2 into the table1.
    Console.WriteLine("Merging");
    table1.Merge(table2, false, MissingSchemaAction.Add);
    PrintValues(table1, "Merged With table1, schema added");

}

private static void Row_Changed(object sender, 
    DataRowChangeEventArgs e)
{
    Console.WriteLine("Row changed {0}\t{1}", e.Action, 
        e.Row.ItemArray[0]);
}

private static void PrintValues(DataTable table, string label)
{
    // Display the values in the supplied DataTable:
    Console.WriteLine(label);
    foreach (DataRow row in table.Rows)
    {
        foreach (DataColumn col in table.Columns)
        {
            Console.Write("\t " + row[col].ToString());
        }
        Console.WriteLine();
    }
}
Private Sub DemonstrateMergeTable()
  Dim table1 As New DataTable("Items")

  ' Add columns
  Dim idColumn As New DataColumn("id", GetType(System.Int32))
  Dim itemColumn As New DataColumn("item", GetType(System.Int32))
  table1.Columns.Add(idColumn)
  table1.Columns.Add(itemColumn)

  ' Set the primary key column.
  table1.PrimaryKey = New DataColumn() {idColumn}

  ' Add RowChanged event handler for the table.
  AddHandler table1.RowChanged, AddressOf Row_Changed

  ' Add some rows.
  Dim row As DataRow
  For i As Integer = 0 To 3
    row = table1.NewRow()
    row("id") = i
    row("item") = i
    table1.Rows.Add(row)
  Next i

  ' Accept changes.
  table1.AcceptChanges()
  PrintValues(table1, "Original values")

  ' Create a second DataTable identical to the first.
  Dim table2 As DataTable = table1.Clone()

  ' Add column to the second column, so that the 
  ' schemas no longer match.
  table2.Columns.Add("newColumn", GetType(System.String))

  ' Add three rows. Note that the id column can't be the 
  ' same as existing rows in the original table.
  row = table2.NewRow()
  row("id") = 14
  row("item") = 774
  row("newColumn") = "new column 1"
  table2.Rows.Add(row)

  row = table2.NewRow()
  row("id") = 12
  row("item") = 555
  row("newColumn") = "new column 2"
  table2.Rows.Add(row)

  row = table2.NewRow()
  row("id") = 13
  row("item") = 665
  row("newColumn") = "new column 3"
  table2.Rows.Add(row)

  ' Merge table2 into the table1.
  Console.WriteLine("Merging")
  table1.Merge(table2, False, MissingSchemaAction.Add)
  PrintValues(table1, "Merged With table1, Schema added")
End Sub

Private Sub Row_Changed(ByVal sender As Object, _
      ByVal e As DataRowChangeEventArgs)
  Console.WriteLine("Row changed {0}{1}{2}", _
    e.Action, ControlChars.Tab, e.Row.ItemArray(0))
End Sub

Private Sub PrintValues(ByVal table As DataTable, _
      ByVal label As String)
  ' Display the values in the supplied DataTable:
  Console.WriteLine(label)
  For Each row As DataRow In table.Rows
    For Each col As DataColumn In table.Columns
      Console.Write(ControlChars.Tab + " " + row(col).ToString())
    Next col
    Console.WriteLine()
  Next row
End Sub

Hinweise

Die Merge -Methode wird verwendet, um DataTable zwei-Objekte zusammenzuführen, die überwiegend ähnliche Schemas aufweisen.The Merge method is used to merge two DataTable objects that have largely similar schemas. Ein Merge wird in der Regel für eine Client Anwendung verwendet, um die neuesten Änderungen aus einer Datenquelle in DataTableeine vorhandene zu integrieren.A merge is typically used on a client application to incorporate the latest changes from a data source into an existing DataTable. Dies ermöglicht es der Client Anwendung, eine DataTable aktualisierte mit den neuesten Daten aus der Datenquelle zu erhalten.This allows the client application to have a refreshed DataTable with the latest data from the data source.

Beim Mergevorgang werden nur die ursprüngliche Tabelle und die zusammen zuführende Tabelle berücksichtigt.The merge operation takes into account only the original table, and the table to be merged. Untergeordnete Tabellen sind nicht betroffen oder enthalten.Child tables are not affected or included. Wenn eine Tabelle über eine oder mehrere untergeordnete Tabellen verfügt, die als Teil einer Beziehung definiert sind, muss jede untergeordnete Tabelle einzeln zusammengeführt werden.If a table has one or more child tables, defined as part of a relationship, each child table must be merged individually.

Merge(DataTable, Boolean, MissingSchemaAction)

Führen Sie die angegebene DataTable mit der aktuellen DataTable zusammen, und geben Sie an, ob die Änderungen in der aktuellen DataTable beibehalten werden sollen und wie das fehlende Schema behandelt werden soll.Merge the specified DataTable with the current DataTable, indicating whether to preserve changes and how to handle missing schema in the current DataTable.

public:
 void Merge(System::Data::DataTable ^ table, bool preserveChanges, System::Data::MissingSchemaAction missingSchemaAction);
public void Merge (System.Data.DataTable table, bool preserveChanges, System.Data.MissingSchemaAction missingSchemaAction);
member this.Merge : System.Data.DataTable * bool * System.Data.MissingSchemaAction -> unit

Parameter

table
DataTable

Die DataTable, die mit der aktuellen DataTable zusammengeführt werden soll.The DataTable to be merged with the current DataTable.

preserveChanges
Boolean

true, um an der aktuellen DataTable vorgenommene Änderungen beizubehalten, andernfalls false.true, to preserve changes in the current DataTable; otherwise false.

missingSchemaAction
MissingSchemaAction

Einer der MissingSchemaAction-Werte.One of the MissingSchemaAction values.

Beispiele

In der folgenden Konsolenanwendung wird das Verhalten missingSchemaAction des-Parameters Merge der-Methode veranschaulicht.The following console application demonstrates the behavior of the missingSchemaAction parameter of the Merge method. In diesem Beispiel werden zwei Versionen derselben Tabelle erstellt, wobei das Schema für die zweite Version geändert wird.This example creates two versions of the same table, modifying the schema for the second version. Der Code versucht dann, die zweite Tabelle mit der ersten zu verbinden.The code then attempts to merge the second table into the first.

private static void DemonstrateMergeTable()
{
    DataTable itemsTable = new DataTable("Items");

    // Add columns
    DataColumn idColumn = new DataColumn("id", typeof(System.Int32));
    DataColumn itemColumn = new DataColumn("item", typeof(System.Int32));
    itemsTable.Columns.Add(idColumn);
    itemsTable.Columns.Add(itemColumn);

    // Set the primary key column.
    itemsTable.PrimaryKey = new DataColumn[] { idColumn };

    // Add RowChanged event handler for the table.
    itemsTable.RowChanged += 
        new System.Data.DataRowChangeEventHandler(Row_Changed);

    // Add ten rows.
    DataRow row;
    for (int i = 0; i <= 9; i++)
    {
        row = itemsTable.NewRow();
        row["id"] = i;
        row["item"] = i;
        itemsTable.Rows.Add(row);
    }

    // Accept changes.
    itemsTable.AcceptChanges();
    PrintValues(itemsTable, "Original values");

    // Create a second DataTable identical to the first.
    DataTable itemsClone = itemsTable.Clone();

    // Add column to the second column, so that the 
    // schemas no longer match.
    itemsClone.Columns.Add("newColumn", typeof(System.String));

    // Add three rows. Note that the id column can't be the 
    // same as existing rows in the original table.
    row = itemsClone.NewRow();
    row["id"] = 14;
    row["item"] = 774;
    row["newColumn"] = "new column 1";
    itemsClone.Rows.Add(row);

    row = itemsClone.NewRow();
    row["id"] = 12;
    row["item"] = 555;
    row["newColumn"] = "new column 2";
    itemsClone.Rows.Add(row);

    row = itemsClone.NewRow();
    row["id"] = 13;
    row["item"] = 665;
    row["newColumn"] = "new column 3";
    itemsClone.Rows.Add(row);

    // Merge itemsClone into the itemsTable.
    Console.WriteLine("Merging");
    itemsTable.Merge(itemsClone, false, MissingSchemaAction.Add);
    PrintValues(itemsTable, "Merged With itemsTable, schema added");
}

private static void Row_Changed(object sender, 
    DataRowChangeEventArgs e)
{
    Console.WriteLine("Row changed {0}\t{1}", 
        e.Action, e.Row.ItemArray[0]);
}

private static void PrintValues(DataTable table, string label)
{
    // Display the values in the supplied DataTable:
    Console.WriteLine(label);
    foreach (DataRow row in table.Rows)
    {
        foreach (DataColumn col in table.Columns)
        {
            Console.Write("\t " + row[col].ToString());
        }
        Console.WriteLine();
    }
}
Private Sub DemonstrateMergeTable()
  Dim itemsTable As New DataTable("Items")

  ' Add columns
  Dim idColumn As New DataColumn("id", GetType(System.Int32))
  Dim itemColumn As New DataColumn("item", GetType(System.Int32))
  itemsTable.Columns.Add(idColumn)
  itemsTable.Columns.Add(itemColumn)

  ' Set the primary key column.
  itemsTable.PrimaryKey = New DataColumn() {idColumn}

  ' Add RowChanged event handler for the table.
  AddHandler itemsTable.RowChanged, AddressOf Row_Changed

  ' Add some rows.
  Dim row As DataRow
  For i As Integer = 0 To 3
    row = itemsTable.NewRow()
    row("id") = i
    row("item") = i
    itemsTable.Rows.Add(row)
  Next i

  ' Accept changes.
  itemsTable.AcceptChanges()
  PrintValues(itemsTable, "Original values")

  ' Create a second DataTable identical to the first.
  Dim itemsClone As DataTable = itemsTable.Clone()

  ' Add column to the second column, so that the 
  ' schemas no longer match.
  itemsClone.Columns.Add("newColumn", GetType(System.String))

  ' Add three rows. Note that the id column can't be the 
  ' same as existing rows in the original table.
  row = itemsClone.NewRow()
  row("id") = 14
  row("item") = 774
  row("newColumn") = "new column 1"
  itemsClone.Rows.Add(row)

  row = itemsClone.NewRow()
  row("id") = 12
  row("item") = 555
  row("newColumn") = "new column 2"
  itemsClone.Rows.Add(row)

  row = itemsClone.NewRow()
  row("id") = 13
  row("item") = 665
  row("newColumn") = "new column 3"
  itemsClone.Rows.Add(row)

  ' Merge itemsClone into the itemsTable.
  Console.WriteLine("Merging")
  itemsTable.Merge(itemsClone, False, MissingSchemaAction.Add)
  PrintValues(itemsTable, "Merged With itemsTable, Schema added")
End Sub

Private Sub Row_Changed(ByVal sender As Object, _
  ByVal e As DataRowChangeEventArgs)
  Console.WriteLine("Row changed {0}{1}{2}", _
    e.Action, ControlChars.Tab, e.Row.ItemArray(0))
End Sub

Private Sub PrintValues(ByVal table As DataTable, ByVal label As String)
  ' Display the values in the supplied DataTable:
  Console.WriteLine(label)
  For Each row As DataRow In table.Rows
    For Each col As DataColumn In table.Columns
      Console.Write(ControlChars.Tab + " " + row(col).ToString())
    Next col
    Console.WriteLine()
  Next row
End Sub

Hinweise

Die Merge -Methode wird verwendet, um DataTable zwei-Objekte zusammenzuführen, die überwiegend ähnliche Schemas aufweisen.The Merge method is used to merge two DataTable objects that have largely similar schemas. Ein Merge wird in der Regel für eine Client Anwendung verwendet, um die neuesten Änderungen aus einer Datenquelle in DataTableeine vorhandene zu integrieren.A merge is typically used on a client application to incorporate the latest changes from a data source into an existing DataTable. Dies ermöglicht es der Client Anwendung, eine DataTable aktualisierte mit den neuesten Daten aus der Datenquelle zu erhalten.This allows the client application to have a refreshed DataTable with the latest data from the data source.

Beim Mergevorgang werden nur die ursprüngliche Tabelle und die zusammen zuführende Tabelle berücksichtigt.The merge operation takes into account only the original table, and the table to be merged. Untergeordnete Tabellen sind nicht betroffen oder enthalten.Child tables are not affected or included. Wenn eine Tabelle über eine oder mehrere untergeordnete Tabellen verfügt, die als Teil einer Beziehung definiert sind, muss jede untergeordnete Tabelle einzeln zusammengeführt werden.If a table has one or more child tables, defined as part of a relationship, each child table must be merged individually.

Die Merge -Methode wird in der Regel am Ende einer Reihe von Prozeduren aufgerufen, die das Überprüfen von Änderungen, das Abgleichen von Fehlern, das Aktualisieren der Datenquelle DataTablemit den Änderungen und schließlich das Aktualisieren des vorhandenen beinhalten.The Merge method is typically called at the end of a series of procedures that involve validating changes, reconciling errors, updating the data source with the changes, and finally refreshing the existing DataTable.

Beim Ausführen einer Zusammenführung werden Änderungen, die vor der Zusammenführung an den vorhandenen Daten vorgenommen werden, während des MERGE-Vorgangs beibehalten, preserveChanges es sei denn, der Entwickler gibt false für den Parameter anWhen performing a merge, changes made to the existing data before the merge are preserved during the merge operation unless the developer specifies false for the preserveChanges parameter. Wenn der preserveChanges -Parameter auf truefestgelegt ist, überschreiben eingehende Werte keine vorhandenen Werte in der aktuellen Zeilen Version der vorhandenen Zeile.If the preserveChanges parameter is set to true, incoming values do not overwrite existing values in the Current row version of the existing row. Wenn der preserveChanges -Parameter auf falsefestgelegt ist, überschreiben eingehende Werte die vorhandenen Werte in der aktuellen Zeilen Version der vorhandenen Zeile.If the preserveChanges parameter is set to false, incoming values do overwrite the existing values in the Current row version of the existing row. Weitere Informationen zu Zeilen Versionen finden Sie unter Zeilen Status und Zeilen Versionen.For more information about row versions, see Row States and Row Versions.

In einer Client Anwendung ist es üblich, dass Sie auf eine einzelne Schaltfläche klicken, auf die der Benutzer klicken kann, um die geänderten Daten zu erfassen und zu überprüfen, bevor Sie Sie an eine Komponente der mittleren Ebene zurücksenden.In a client application, it is usual to have a single button that the user can click that gathers the changed data and validates it before sending it back to a middle tier component. In diesem Szenario wird zuerst GetChanges die-Methode aufgerufen.In this scenario, the GetChanges method is first invoked. Diese Methode gibt eine Sekunde DataTable zurück, die für die Validierung und Zusammenführung optimiert ist.That method returns a second DataTable optimized for validating and merging. Dieses zweite DataTable Objekt enthält nur das DataTable - DataRow Objekt und das-Objekt, die geändert wurden, was zu einer DataTableTeilmenge des Originals führte.This second DataTable object contains only the DataTable and DataRow objects that were changed, resulting in a subset of the original DataTable. Diese Teilmenge ist im Allgemeinen kleiner, und daher wird diese Teilmenge effizienter an eine Komponente der mittleren Ebene zurückgegeben.This subset is generally smaller, and thus this subset is more efficiently passed back to a middle tier component. Die Komponente der mittleren Ebene aktualisiert dann die ursprüngliche Datenquelle mit den Änderungen durch gespeicherte Prozeduren.The middle tier component then updates the original data source with the changes through stored procedures. Die mittlere Ebene kann dann entweder eine neue DataTable zurücksenden, die die ursprünglichen Daten und die neuesten Daten aus der Datenquelle enthält (durch erneutes Ausführen der ursprünglichen Abfrage), oder Sie kann die Teilmenge mit allen Änderungen zurücksenden, die an der Datenquelle vorgenommen wurden.The middle tier can then send back either a new DataTable that includes original data and the latest data from the data source (by running the original query again), or it can send back the subset with any changes that have been made to it from the data source. (Wenn die Datenquelle z. b. automatisch eindeutige Primärschlüssel Werte erstellt, können diese Werte an die Client Anwendung zurückgegeben werden.) In beiden Fällen kann die zurück DataTable gegebene mit der Merge -Methode wieder mit der ursprünglichen DataTable Client Anwendung zusammengeführt werden.(For example, if the data source automatically creates unique primary key values, these values can be propagated back to the client application.) In either case, the returned DataTable can be merged back into the client application's original DataTable with the Merge method.

Wenn die Merge -Methode aufgerufen wird, werden die Schemas der DataTable beiden-Objekte verglichen, da es möglich ist, dass die Schemas geändert wurden.When the Merge method is called, the schemas of the two DataTable objects are compared, because it is possible that the schemas may have been changed. Beispielsweise können in einem Business-to-Business-Szenario neue Spalten einem XML-Schema durch einen automatisierten Prozess hinzugefügt werden.For example, in a business-to-business scenario, new columns may have been added to an XML schema by an automated process. Wenn die Quelle DataTable Schema Elemente (hinzugefügte DataColumn Objekte) enthält, die im Ziel fehlen, können die Schema Elemente dem Ziel hinzugefügt werden, indem missingSchemaAction das- MissingSchemaAction.AddArgument auf festgelegt wird.If the source DataTable contains schema elements (added DataColumn objects) that are missing in the target, the schema elements can be added to the target by setting the missingSchemaAction argument to MissingSchemaAction.Add. In diesem Fall enthält das zusammen DataTable geführte das hinzugefügte Schema und die Daten.In that case, the merged DataTable contains the added schema and data.

Nach dem Zusammenführen von Schemas werden die Daten zusammengeführt.After merging schemas, the data is merged.

Beim Zusammenführen einer neuen DataTable Quelle DataRowState mit dem Ziel werden alle Quellzeilen mit dem Wert Unchanged, Modifiedoder Deleted mit den Ziel Zeilen mit denselben Primärschlüssel Werten abgeglichen.When merging a new source DataTable into the target, any source rows with a DataRowState value of Unchanged, Modified, or Deleted are matched to target rows with the same primary key values. Quellzeilen mit DataRowState dem Added Wert werden mit den neuen Ziel Zeilen mit denselben Primärschlüssel Werten wie die neuen Quellzeilen abgeglichen.Source rows with a DataRowState value of Added are matched to new target rows with the same primary key values as the new source rows.

Siehe auch

Merge(DataTable, Boolean)

Führen Sie die angegebene DataTable mit der aktuellen DataTable zusammen, und geben Sie an, ob die Änderungen in der aktuellen DataTable beibehalten werden sollen.Merge the specified DataTable with the current DataTable, indicating whether to preserve changes in the current DataTable.

public:
 void Merge(System::Data::DataTable ^ table, bool preserveChanges);
public void Merge (System.Data.DataTable table, bool preserveChanges);
member this.Merge : System.Data.DataTable * bool -> unit
Public Sub Merge (table As DataTable, preserveChanges As Boolean)

Parameter

table
DataTable

Die DataTable, die mit der aktuellen DataTable zusammengeführt werden soll.The DataTable to be merged with the current DataTable.

preserveChanges
Boolean

true, um an der aktuellen DataTable vorgenommene Änderungen beizubehalten, andernfalls false.true, to preserve changes in the current DataTable; otherwise false.

Beispiele

Die folgende Konsolenanwendung erstellt eine DataTable , die Zeilen enthält, ändert einige der Daten in diesen Zeilen und versucht, Daten aus einer anderen DataTablezusammenzuführen.The following console application creates a DataTable containing rows, modifies some of the data in those rows, and attempts to merge data from a different DataTable. Das Beispiel veranschaulicht die unterschiedlichen Verhaltensweisen preserveChanges für den-Parameter.The example demonstrates the different behaviors for the preserveChanges parameter.


private static void DemonstrateMergeTable()
{
    // Demonstrate merging, within and without
    // preserving changes.

    // In this example, take these actions:
    // 1. Create a DataTable (table1) and fill the table with data.
    // 2. Create a copy of table1, and modify its data (modifiedTable).
    // 3. Modify data in table1.
    // 4. Make a copy of table1 (table1Copy).
    // 5. Merge the data from modifiedTable into table1 and table1Copy, 
    //    showing the difference between setting the preserveChanges 
    //    parameter to true and false.

    // Create a new DataTable.
    DataTable table1 = new DataTable("Items");

    // Add two columns to the table:
    DataColumn column = new DataColumn("id", typeof(System.Int32));
    column.AutoIncrement = true;
    table1.Columns.Add(column);

    column = new DataColumn("item", typeof(System.String));
    table1.Columns.Add(column);

    // Set primary key column.
    table1.PrimaryKey = new DataColumn[] { table1.Columns[0] };

    // Add some rows.
    DataRow row;
    for (int i = 0; i <= 3; i++)
    {
        row = table1.NewRow();
        row["item"] = "Item " + i;
        table1.Rows.Add(row);
    }

    // Accept changes.
    table1.AcceptChanges();
    PrintValues(table1, "Original values");

    // Using the same schema as the original table, 
    // modify the data for later merge.
    DataTable modifiedTable = table1.Copy();
    foreach (DataRow rowModified in modifiedTable.Rows)
    {
        rowModified["item"] = rowModified["item"].ToString() 
            + " modified";
    }
    modifiedTable.AcceptChanges();

    // Change row values, and add a new row:
    table1.Rows[0]["item"] = "new Item 0";
    table1.Rows[1]["item"] = "new Item 1";

    row = table1.NewRow();
    row["id"] = 4;
    row["item"] = "Item 4";
    table1.Rows.Add(row);

    // Get a copy of the modified data:
    DataTable table1Copy = table1.Copy();
    PrintValues(table1, "Modified and new Values");
    PrintValues(modifiedTable, "Data to be merged into table1");

    // Merge new data into the modified data.
    table1.Merge(modifiedTable, true);
    PrintValues(table1, "Merged data (preserve changes)");

    table1Copy.Merge(modifiedTable, false);
    PrintValues(modifiedTable, "Merged data (don't preserve changes)");
}


private static void PrintValues(DataTable table, string label)
{
    // Display the values in the supplied DataTable:
    Console.WriteLine(label);
    foreach (DataRow row in table.Rows)
    {
        foreach (DataColumn column in table.Columns)
        {
            Console.Write("\t{0}", row[column, DataRowVersion.Current]);
        }
        Console.WriteLine();
    }
}
Private Sub DemonstrateMergeTable()
  ' Demonstrate merging, within and without
  ' preserving changes.

  ' In this example, take these actions:
  ' 1. Create a DataTable (table1) and fill the table with data.
  ' 2. Create a copy of table1, and modify its data (modifiedTable).
  ' 3. Modify data in table1.
  ' 4. Make a copy of table1 (table1Copy).
  ' 5. Merge the data from modifiedTable into table1 and table1Copy, 
  '    showing the difference between setting the preserveChanges 
  '    parameter to true and false.

  ' Create a new DataTable.
  Dim table1 As New DataTable("Items")

  ' Add two columns to the table:
  Dim column As New DataColumn("id", GetType(System.Int32))
  column.AutoIncrement = True
  table1.Columns.Add(column)

  column = New DataColumn("item", GetType(System.String))
  table1.Columns.Add(column)

  ' Set primary key column.
  table1.PrimaryKey = New DataColumn() {table1.Columns(0)}

  ' Add some rows.
  Dim row As DataRow
  For i As Integer = 0 To 3
    row = table1.NewRow()
    row("item") = "Item " & i
    table1.Rows.Add(row)
  Next i

  ' Accept changes.
  table1.AcceptChanges()
  PrintValues(table1, "Original values")

  ' Using the same schema as the original table, 
  ' modify the data for later merge.
  Dim modifiedTable As DataTable = table1.Copy()
  For Each row In modifiedTable.Rows
    row("item") = row("item").ToString() & " modified"
  Next
  modifiedTable.AcceptChanges()

  ' Change row values, and add a new row:
  table1.Rows(0)("item") = "New Item 0"
  table1.Rows(1)("item") = "New Item 1"

  row = table1.NewRow()
  row("id") = 4
  row("item") = "Item 4"
  table1.Rows.Add(row)

  ' Get a copy of the modified data:
  Dim table1Copy As DataTable = table1.Copy()
  PrintValues(table1, "Modified and New Values")
  PrintValues(modifiedTable, "Data to be merged into table1")


  ' Merge new data into the modified data.
  table1.Merge(modifiedTable, True)
  PrintValues(table1, "Merged data (preserve changes)")

  table1Copy.Merge(modifiedTable, False)
  PrintValues(modifiedTable, "Merged data (don't preserve changes)")

End Sub

Private Sub PrintValues(ByVal table As DataTable, _
  ByVal label As String)

  ' Display the values in the supplied DataTable:
  Console.WriteLine(label)
  For Each row As DataRow In table.Rows
    For Each column As DataColumn In table.Columns
      Console.Write("{0}{1}", ControlChars.Tab, row(column, _
          DataRowVersion.Current))
    Next column
    Console.WriteLine()
  Next row
End Sub

Hinweise

Die Merge-Methode wird verwendet, um DataTable zwei Objekte zusammenzuführen, die überwiegend ähnliche Schemas aufweisen.The Merge method is used to merge two DataTable objects that have largely similar schemas. Ein Merge wird in der Regel für eine Client Anwendung verwendet, um die neuesten Änderungen aus einer Datenquelle in DataTableeine vorhandene zu integrieren.A merge is typically used on a client application to incorporate the latest changes from a data source into an existing DataTable. Dies ermöglicht es der Client Anwendung, eine DataTable aktualisierte mit den neuesten Daten aus der Datenquelle zu erhalten.This allows the client application to have a refreshed DataTable with the latest data from the data source.

Beim Mergevorgang werden nur die ursprüngliche Tabelle und die zusammen zuführende Tabelle berücksichtigt.The merge operation takes into account only the original table, and the table to be merged. Untergeordnete Tabellen sind nicht betroffen oder enthalten.Child tables are not affected or included. Wenn eine Tabelle über eine oder mehrere untergeordnete Tabellen verfügt, die als Teil einer Beziehung definiert sind, muss jede untergeordnete Tabelle einzeln zusammengeführt werden.If a table has one or more child tables, defined as part of a relationship, each child table must be merged individually.

Die Merge -Methode wird in der Regel am Ende einer Reihe von Prozeduren aufgerufen, die das Überprüfen von Änderungen, das Abgleichen von Fehlern, das Aktualisieren der Datenquelle DataTablemit den Änderungen und schließlich das Aktualisieren des vorhandenen beinhalten.The Merge method is typically called at the end of a series of procedures that involve validating changes, reconciling errors, updating the data source with the changes, and finally refreshing the existing DataTable.

Beim Ausführen einer Zusammenführung werden Änderungen, die vor der Zusammenführung an den vorhandenen Daten vorgenommen werden, während des MERGE-Vorgangs beibehalten, preserveChanges es sei denn, der Entwickler gibt false für den Parameter anWhen performing a merge, changes made to the existing data before the merge are preserved during the merge operation unless the developer specifies false for the preserveChanges parameter. Wenn der preserveChanges -Parameter auf truefestgelegt ist, überschreiben eingehende Werte keine vorhandenen Werte in der aktuellen Zeilen Version der vorhandenen Zeile.If the preserveChanges parameter is set to true, incoming values do not overwrite existing values in the Current row version of the existing row. Wenn der preserveChanges -Parameter auf falsefestgelegt ist, überschreiben eingehende Werte die vorhandenen Werte in der aktuellen Zeilen Version der vorhandenen Zeile.If the preserveChanges parameter is set to false, incoming values do overwrite the existing values in the Current row version of the existing row. Weitere Informationen zu Zeilen Versionen finden Sie unter Zeilen Status und Zeilen Versionen.For more information about row versions, see Row States and Row Versions.

In einer Client Anwendung ist es üblich, dass Sie auf eine einzelne Schaltfläche klicken, auf die der Benutzer klicken kann, um die geänderten Daten zu erfassen und zu überprüfen, bevor Sie Sie an eine Komponente der mittleren Ebene zurücksenden.In a client application, it is usual to have a single button that the user can click that gathers the changed data and validates it before sending it back to a middle tier component. In diesem Szenario wird zuerst GetChanges die-Methode aufgerufen.In this scenario, the GetChanges method is first invoked. Diese Methode gibt eine Sekunde DataTable zurück, die für die Validierung und Zusammenführung optimiert ist.That method returns a second DataTable optimized for validating and merging. Dieses zweite DataTable Objekt enthält nur das DataTable - DataRow Objekt und das-Objekt, die geändert wurden, was zu einer DataTableTeilmenge des Originals führte.This second DataTable object contains only the DataTable and DataRow objects that were changed, resulting in a subset of the original DataTable. Diese Teilmenge ist im Allgemeinen kleiner, und daher wird diese Teilmenge effizienter an eine Komponente der mittleren Ebene zurückgegeben.This subset is generally smaller, and thus this subset is more efficiently passed back to a middle tier component. Die Komponente der mittleren Ebene aktualisiert dann die ursprüngliche Datenquelle mit den Änderungen durch gespeicherte Prozeduren.The middle tier component then updates the original data source with the changes through stored procedures. Die mittlere Ebene kann dann entweder eine neue DataTable zurücksenden, die die ursprünglichen Daten und die neuesten Daten aus der Datenquelle enthält (durch erneutes Ausführen der ursprünglichen Abfrage), oder Sie kann die Teilmenge mit allen Änderungen zurücksenden, die an der Datenquelle vorgenommen wurden.The middle tier can then send back either a new DataTable that includes original data and the latest data from the data source (by running the original query again), or it can send back the subset with any changes that have been made to it from the data source. (Wenn die Datenquelle z. b. automatisch eindeutige Primärschlüssel Werte erstellt, können diese Werte an die Client Anwendung zurückgegeben werden.) In beiden Fällen kann die zurück DataTable gegebene mit der Merge -Methode wieder mit der ursprünglichen DataTable Client Anwendung zusammengeführt werden.(For example, if the data source automatically creates unique primary key values, these values can be propagated back to the client application.) In either case, the returned DataTable can be merged back into the client application's original DataTable with the Merge method.

Beim Zusammenführen einer neuen DataTable Quelle DataRowState mit dem Ziel werden alle Quellzeilen mit dem Wert Unchanged, Modifiedoder Deleted mit den Ziel Zeilen mit denselben Primärschlüssel Werten abgeglichen.When merging a new source DataTable into the target, any source rows with a DataRowState value of Unchanged, Modified, or Deleted are matched to target rows with the same primary key values. Quellzeilen mit DataRowState dem Added Wert werden mit den neuen Ziel Zeilen mit denselben Primärschlüssel Werten wie die neuen Quellzeilen abgeglichen.Source rows with a DataRowState value of Added are matched to new target rows with the same primary key values as the new source rows.

Siehe auch

Merge(DataTable)

Führen Sie die angegebene DataTable mit der aktuellen DataTable zusammen.Merge the specified DataTable with the current DataTable.

public:
 void Merge(System::Data::DataTable ^ table);
public void Merge (System.Data.DataTable table);
member this.Merge : System.Data.DataTable -> unit
Public Sub Merge (table As DataTable)

Parameter

table
DataTable

Die DataTable, die mit der aktuellen DataTable zusammengeführt werden soll.The DataTable to be merged with the current DataTable.

Beispiele

Die folgende Konsolenanwendung erstellt eine einfache DataTable und fügt der Tabelle Daten hinzu.The following console application creates a simple DataTable and adds data to the table. Im Beispiel wird dann eine Kopie der Tabelle erstellt, wobei der Kopie Zeilen hinzugefügt werden.The example then creates a copy of the table, adding rows to the copy. Zum Schluss ruft das Beispiel die Merge -Methode auf, um die Daten in der zweiten Tabelle mit den Daten in der ersten Tabelle zusammenzuführen.Finally, the example calls the Merge method to merge the data in the second table with the data in the first table.

private static void DemonstrateMergeTable()
{
    DataTable table1 = new DataTable("Items");

    // Add columns
    DataColumn column1 = new DataColumn("id", typeof(System.Int32));
    DataColumn column2 = new DataColumn("item", typeof(System.Int32));
    table1.Columns.Add(column1);
    table1.Columns.Add(column2);

    // Set the primary key column.
    table1.PrimaryKey = new DataColumn[] { column1 };

    // Add RowChanged event handler for the table.
    table1.RowChanged += 
        new System.Data.DataRowChangeEventHandler(Row_Changed);

    // Add some rows.
    DataRow row;
    for (int i = 0; i <= 3; i++)
    {
        row = table1.NewRow();
        row["id"] = i;
        row["item"] = i;
        table1.Rows.Add(row);
    }

    // Accept changes.
    table1.AcceptChanges();
    PrintValues(table1, "Original values");

    // Create a second DataTable identical to the first.
    DataTable table2 = table1.Clone();

    // Add three rows. Note that the id column can't be the 
    // same as existing rows in the original table.
    row = table2.NewRow();
    row["id"] = 14;
    row["item"] = 774;
    table2.Rows.Add(row);

    row = table2.NewRow();
    row["id"] = 12;
    row["item"] = 555;
    table2.Rows.Add(row);

    row = table2.NewRow();
    row["id"] = 13;
    row["item"] = 665;
    table2.Rows.Add(row);

    // Merge table2 into the table1.
    Console.WriteLine("Merging");
    table1.Merge(table2);
    PrintValues(table1, "Merged With table1");

}

private static void Row_Changed(object sender, 
    DataRowChangeEventArgs e)
{
    Console.WriteLine("Row changed {0}\t{1}", 
        e.Action, e.Row.ItemArray[0]);
}

private static void PrintValues(DataTable table, string label)
{
    // Display the values in the supplied DataTable:
    Console.WriteLine(label);
    foreach (DataRow row in table.Rows)
    {
        foreach (DataColumn col in table.Columns)
        {
            Console.Write("\t " + row[col].ToString());
        }
        Console.WriteLine();
    }
}
Private Sub DemonstrateMergeTable()
  Dim table1 As New DataTable("Items")

  ' Add columns
  Dim column1 As New DataColumn("id", GetType(System.Int32))
  Dim column2 As New DataColumn("item", GetType(System.Int32))
  table1.Columns.Add(column1)
  table1.Columns.Add(column2)

  ' Set the primary key column.
  table1.PrimaryKey = New DataColumn() {column1}

  ' Add RowChanged event handler for the table.
  AddHandler table1.RowChanged, AddressOf Row_Changed

  ' Add some rows.
  Dim row As DataRow
  For i As Integer = 0 To 3
    row = table1.NewRow()
    row("id") = i
    row("item") = i
    table1.Rows.Add(row)
  Next i

  ' Accept changes.
  table1.AcceptChanges()
  PrintValues(table1, "Original values")

  ' Create a second DataTable identical to the first.
  Dim table2 As DataTable = table1.Clone()

  ' Add three rows. Note that the id column can't be the 
  ' same as existing rows in the original table.
  row = table2.NewRow()
  row("id") = 14
  row("item") = 774
  table2.Rows.Add(row)

  row = table2.NewRow()
  row("id") = 12
  row("item") = 555
  table2.Rows.Add(row)

  row = table2.NewRow()
  row("id") = 13
  row("item") = 665
  table2.Rows.Add(row)

  ' Merge table2 into the table1.
  Console.WriteLine("Merging")
  table1.Merge(table2)
  PrintValues(table1, "Merged With table1")

End Sub

Private Sub Row_Changed(ByVal sender As Object, _
  ByVal e As DataRowChangeEventArgs)
  Console.WriteLine("Row changed {0}{1}{2}", _
    e.Action, ControlChars.Tab, e.Row.ItemArray(0))
End Sub

Private Sub PrintValues(ByVal table As DataTable, _
  ByVal label As String)
  ' Display the values in the supplied DataTable:
  Console.WriteLine(label)
  For Each row As DataRow In table.Rows
    For Each col As DataColumn In table.Columns
      Console.Write(ControlChars.Tab + " " + row(col).ToString())
    Next col
    Console.WriteLine()
  Next row
End Sub

Hinweise

Die Merge-Methode wird verwendet, um DataTable zwei Objekte zusammenzuführen, die überwiegend ähnliche Schemas aufweisen.The Merge method is used to merge two DataTable objects that have largely similar schemas. Ein Merge wird in der Regel für eine Client Anwendung verwendet, um die neuesten Änderungen aus einer Datenquelle in DataTableeine vorhandene zu integrieren.A merge is typically used on a client application to incorporate the latest changes from a data source into an existing DataTable. Dies ermöglicht es der Client Anwendung, eine DataTable aktualisierte mit den neuesten Daten aus der Datenquelle zu erhalten.This allows the client application to have a refreshed DataTable with the latest data from the data source.

Beim Mergevorgang werden nur die ursprüngliche Tabelle und die zusammen zuführende Tabelle berücksichtigt.The merge operation takes into account only the original table, and the table to be merged. Untergeordnete Tabellen sind nicht betroffen oder enthalten.Child tables are not affected or included. Wenn eine Tabelle über eine oder mehrere untergeordnete Tabellen verfügt, die als Teil einer Beziehung definiert sind, muss jede untergeordnete Tabelle einzeln zusammengeführt werden.If a table has one or more child tables, defined as part of a relationship, each child table must be merged individually.

Die Merge -Methode wird in der Regel am Ende einer Reihe von Prozeduren aufgerufen, die das Überprüfen von Änderungen, das Abgleichen von Fehlern, das Aktualisieren der Datenquelle DataTablemit den Änderungen und schließlich das Aktualisieren des vorhandenen beinhalten.The Merge method is typically called at the end of a series of procedures that involve validating changes, reconciling errors, updating the data source with the changes, and finally refreshing the existing DataTable.

Beim Durchführen einer Zusammenführung werden Änderungen, die vor der Zusammenführung an den vorhandenen Daten vorgenommen wurden, während des MERGE-Vorgangs standardmäßig beibehalten.When performing a merge, changes made to the existing data before the merge are preserved by default during the merge operation. Entwickler können dieses Verhalten ändern, indem Sie eine der beiden anderen über Ladungen für diese Methode aufrufen und einen false-Wert für den preserveChanges -Parameter angeben.Developers can modify this behavior by calling one of the other two overloads for this method, and specifying a false value for the preserveChanges parameter.

In einer Client Anwendung ist es üblich, dass Sie auf eine einzelne Schaltfläche klicken, auf die der Benutzer klicken kann, um die geänderten Daten zu erfassen und zu überprüfen, bevor Sie Sie an eine Komponente der mittleren Ebene zurücksenden.In a client application, it is usual to have a single button that the user can click that gathers the changed data and validates it before sending it back to a middle tier component. In diesem Szenario wird zuerst GetChanges die-Methode aufgerufen.In this scenario, the GetChanges method is first invoked. Diese Methode gibt eine Sekunde DataTable zurück, die für die Validierung und Zusammenführung optimiert ist.That method returns a second DataTable optimized for validating and merging. Dieses zweite DataTable Objekt enthält nur die DataRow Objekte, die geändert wurden, was zu einer Teilmenge des Originals DataTableführte.This second DataTable object contains only the DataRow objects that were changed, resulting in a subset of the original DataTable. Diese Teilmenge ist im Allgemeinen kleiner und wird daher effizienter an eine Komponente der mittleren Ebene zurückgegeben.This subset is generally smaller and thus more efficiently passed back to a middle tier component. Die Komponente der mittleren Ebene aktualisiert dann die ursprüngliche Datenquelle mit den Änderungen durch gespeicherte Prozeduren.The middle tier component then updates the original data source with the changes through stored procedures. Die mittlere Ebene kann dann entweder eine neue DataTable zurücksenden, die die ursprünglichen Daten und die neuesten Daten aus der Datenquelle enthält (durch erneutes Ausführen der ursprünglichen Abfrage), oder Sie kann die Teilmenge mit allen Änderungen zurücksenden, die an der Datenquelle vorgenommen wurden.The middle tier can then send back either a new DataTable that includes original data and the latest data from the data source (by running the original query again), or it can send back the subset with any changes that have been made to it from the data source. (Wenn die Datenquelle z. b. automatisch eindeutige Primärschlüssel Werte erstellt, können diese Werte an die Client Anwendung zurückgegeben werden.) In beiden Fällen kann die zurück DataTable gegebene mit der Merge -Methode wieder mit der ursprünglichen DataTable Client Anwendung zusammengeführt werden.(For example, if the data source automatically creates unique primary key values, these values can be propagated back to the client application.) In either case, the returned DataTable can be merged back into the client application's original DataTable with the Merge method.

Beim Zusammenführen einer neuen DataTable Quelle DataRowState mit dem Ziel werden alle Quellzeilen mit dem Wert Unchanged, Modifiedoder Deletedmit den Ziel Zeilen mit denselben Primärschlüssel Werten abgeglichen.When merging a new source DataTable into the target, any source rows with a DataRowState value of Unchanged, Modified, or Deleted, is matched to target rows with the same primary key values. Quellzeilen mit DataRowState dem Added Wert werden mit den neuen Ziel Zeilen mit denselben Primärschlüssel Werten wie die neuen Quellzeilen abgeglichen.Source rows with a DataRowState value of Added are matched to new target rows with the same primary key values as the new source rows.

Siehe auch

Gilt für: