DataTable.Merge DataTable.Merge DataTable.Merge DataTable.Merge Method

Definizione

Unire la classe DataTable specificata alla classe DataTable corrente.Merge the specified DataTable with the current DataTable.

Overload

Merge(DataTable, Boolean, MissingSchemaAction) Merge(DataTable, Boolean, MissingSchemaAction) Merge(DataTable, Boolean, MissingSchemaAction)

Unire la classe DataTable specificata alla classe DataTable corrente, indicando se conservare le modifiche e come gestire lo schema mancante nella classe DataTable corrente.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) Merge(DataTable, Boolean) Merge(DataTable, Boolean) Merge(DataTable, Boolean)

Unire la classe DataTable specificata alla classe DataTable corrente, indicando se conservare le modifiche nella classe DataTable corrente.Merge the specified DataTable with the current DataTable, indicating whether to preserve changes in the current DataTable.

Merge(DataTable) Merge(DataTable) Merge(DataTable) Merge(DataTable)

Unire la classe DataTable specificata alla classe DataTable corrente.Merge the specified DataTable with the current DataTable.

Esempi

L'applicazione console seguente viene illustrato il comportamento dei missingSchemaAction parametro del Merge (metodo).The following console application demonstrates the behavior of the missingSchemaAction parameter of the Merge method. Questo esempio crea due versioni della stessa tabella, la modifica dello schema per la seconda versione.This example creates two versions of the same table, modifying the schema for the second version. Il codice tenta quindi di unire la seconda tabella al primo oggetto.The code then attempts to merge the second table into the first.

Nota

In questo esempio viene illustrato come utilizzare una delle versioni di overload di tipo Merge.This example shows how to use one of the overloaded versions of Merge. Per altri esempi che potrebbero essere disponibili, vedere gli argomenti di overload singoli.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

Commenti

Il Merge metodo viene usato per unire due DataTable gli oggetti che contengono schemi molto simili.The Merge method is used to merge two DataTable objects that have largely similar schemas. Un'unione nell'indice è in genere usato in un'applicazione client per incorporare le modifiche più recenti da un'origine dati in un oggetto esistente DataTable.A merge is typically used on a client application to incorporate the latest changes from a data source into an existing DataTable. In questo modo l'applicazione client avere un oggetto aggiornato DataTable con i dati più recenti dall'origine dati.This allows the client application to have a refreshed DataTable with the latest data from the data source.

L'operazione di unione prende in considerazione solo la tabella originale e la tabella da unire.The merge operation takes into account only the original table, and the table to be merged. Tabelle figlio non vengono modificate o inclusi.Child tables are not affected or included. Se una tabella include una o più tabelle figlio, definite come parte di una relazione, ogni tabella figlio deve essere unito singolarmente.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) Merge(DataTable, Boolean, MissingSchemaAction) Merge(DataTable, Boolean, MissingSchemaAction)

Unire la classe DataTable specificata alla classe DataTable corrente, indicando se conservare le modifiche e come gestire lo schema mancante nella classe DataTable corrente.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

Parametri

table
DataTable DataTable DataTable DataTable

Classe DataTable da unire alla classe DataTable corrente.The DataTable to be merged with the current DataTable.

preserveChanges
Boolean Boolean Boolean Boolean

true per conservare le modifiche apportate all'oggetto DataTable corrente; in caso contrario, false.true, to preserve changes in the current DataTable; otherwise false.

Esempi

L'applicazione console seguente viene illustrato il comportamento dei missingSchemaAction parametro del Merge (metodo).The following console application demonstrates the behavior of the missingSchemaAction parameter of the Merge method. Questo esempio crea due versioni della stessa tabella, la modifica dello schema per la seconda versione.This example creates two versions of the same table, modifying the schema for the second version. Il codice tenta quindi di unire la seconda tabella al primo oggetto.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

Commenti

Il Merge metodo viene usato per unire due DataTable gli oggetti che contengono schemi molto simili.The Merge method is used to merge two DataTable objects that have largely similar schemas. Un'unione nell'indice è in genere usato in un'applicazione client per incorporare le modifiche più recenti da un'origine dati in un oggetto esistente DataTable.A merge is typically used on a client application to incorporate the latest changes from a data source into an existing DataTable. In questo modo l'applicazione client avere un oggetto aggiornato DataTable con i dati più recenti dall'origine dati.This allows the client application to have a refreshed DataTable with the latest data from the data source.

L'operazione di unione prende in considerazione solo la tabella originale e la tabella da unire.The merge operation takes into account only the original table, and the table to be merged. Tabelle figlio non vengono modificate o inclusi.Child tables are not affected or included. Se una tabella include una o più tabelle figlio, definite come parte di una relazione, ogni tabella figlio deve essere unito singolarmente.If a table has one or more child tables, defined as part of a relationship, each child table must be merged individually.

Il Merge viene chiamato in genere alla fine di una serie di procedure che comportano la convalida delle modifiche, la risoluzione degli errori, aggiornare l'origine dati con le modifiche e infine l'aggiornamento esistente DataTable.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.

Quando si esegue un'operazione di unione, le modifiche apportate ai dati esistenti prima dell'unione vengono conservate durante l'operazione di unione, a meno che lo sviluppatore specifica false per il preserveChanges parametro.When 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. Se il preserveChanges parametro è impostato su true, i valori in ingresso non sovrascrivano i valori esistenti nella versione di riga corrente della riga esistente.If the preserveChanges parameter is set to true, incoming values do not overwrite existing values in the Current row version of the existing row. Se il preserveChanges parametro è impostato su false, i valori in ingresso verranno sovrascritti i valori esistenti nella versione di riga corrente della riga esistente.If the preserveChanges parameter is set to false, incoming values do overwrite the existing values in the Current row version of the existing row. Per altre informazioni sulle versioni delle righe, vedere stati e le versioni delle righe.For more information about row versions, see Row States and Row Versions.

In un'applicazione client, è normale avere un unico pulsante che l'utente può scegliere che raccoglie i dati modificati e la convalida prima di inviarlo a un componente di livello intermedio.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 questo scenario il GetChanges metodo viene richiamato prima di tutto.In this scenario, the GetChanges method is first invoked. Questo metodo restituisce un secondo DataTable ottimizzato per la convalida e l'unione.That method returns a second DataTable optimized for validating and merging. Questa seconda DataTable oggetto contiene solo le DataTable e DataRow oggetti che sono stati modificati, causando un sottoinsieme dell'oggetto originale DataTable.This second DataTable object contains only the DataTable and DataRow objects that were changed, resulting in a subset of the original DataTable. Questo subset è generalmente di dimensioni ridotte e pertanto questo subset è più efficiente passare a un componente di livello intermedio.This subset is generally smaller, and thus this subset is more efficiently passed back to a middle tier component. Il componente di livello intermedio aggiorna quindi l'origine dati originale con le modifiche mediante le stored procedure.The middle tier component then updates the original data source with the changes through stored procedures. Il livello intermedio può quindi inviare un nuovo oggetto DataTable che include dati originali e i dati più recenti dall'origine dati (per eseguire nuovamente la query originale), oppure che venga inviato nuovamente il subset con eventuali modifiche apportate a esso dall'origine dati.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. (Ad esempio, se l'origine dati crea automaticamente i valori di chiave primari univoca, questi valori possono essere propagati all'applicazione client.) In entrambi i casi, l'oggetto restituito DataTable può essere nuovamente uniti in originale dell'applicazione client DataTable con il Merge (metodo).(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.

Quando la Merge metodo viene chiamato, gli schemi dei due DataTable vengono confrontati gli oggetti, poiché è possibile che gli schemi sia stati modificati.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. Ad esempio, in uno scenario business-to-business, potrebbero sono state aggiunte nuove colonne in un XML schema da un processo automatizzato.For example, in a business-to-business scenario, new columns may have been added to an XML schema by an automated process. Se l'origine DataTable contiene gli elementi dello schema (aggiunto DataColumn oggetti) che non sono presenti nel database di destinazione, è possono aggiungere gli elementi dello schema di destinazione impostando le missingSchemaAction argomento MissingSchemaAction.Add.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 tal caso, l'oggetto unito DataTable contiene lo schema e aggiunti dati.In that case, the merged DataTable contains the added schema and data.

Dopo aver unito gli schemi, i dati vengono uniti.After merging schemas, the data is merged.

Durante il merge di una nuova origine DataTable nella destinazione, qualsiasi origine righe con un DataRowState pari a Unchanged, Modified, o Deleted corrispondono alle righe di destinazione con gli stessi valori di chiave primari.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. Origine le righe con un DataRowState pari a Added corrispondono alle nuove righe di destinazione con gli stessi valori di chiave primari come le nuove righe di origine.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.

Vedi anche

Merge(DataTable, Boolean) Merge(DataTable, Boolean) Merge(DataTable, Boolean) Merge(DataTable, Boolean)

Unire la classe DataTable specificata alla classe DataTable corrente, indicando se conservare le modifiche nella classe DataTable corrente.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)

Parametri

table
DataTable DataTable DataTable DataTable

Classe DataTable da unire alla classe DataTable corrente.The DataTable to be merged with the current DataTable.

preserveChanges
Boolean Boolean Boolean Boolean

true per conservare le modifiche apportate all'oggetto DataTable corrente; in caso contrario, false.true, to preserve changes in the current DataTable; otherwise false.

Esempi

La seguente applicazione console crea un DataTable contenente le righe, consente di modificare alcuni dei dati delle righe e tenta di unire dati da un altro DataTable.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. Nell'esempio vengono illustrati i diversi comportamenti di preserveChanges parametro.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

Commenti

Il metodo Merge viene utilizzato per unire due DataTable gli oggetti che contengono schemi molto simili.The Merge method is used to merge two DataTable objects that have largely similar schemas. Un'unione nell'indice è in genere usato in un'applicazione client per incorporare le modifiche più recenti da un'origine dati in un oggetto esistente DataTable.A merge is typically used on a client application to incorporate the latest changes from a data source into an existing DataTable. In questo modo l'applicazione client avere un oggetto aggiornato DataTable con i dati più recenti dall'origine dati.This allows the client application to have a refreshed DataTable with the latest data from the data source.

L'operazione di unione prende in considerazione solo la tabella originale e la tabella da unire.The merge operation takes into account only the original table, and the table to be merged. Tabelle figlio non vengono modificate o inclusi.Child tables are not affected or included. Se una tabella include una o più tabelle figlio, definite come parte di una relazione, ogni tabella figlio deve essere unito singolarmente.If a table has one or more child tables, defined as part of a relationship, each child table must be merged individually.

Il Merge viene chiamato in genere alla fine di una serie di procedure che comportano la convalida delle modifiche, la risoluzione degli errori, aggiornare l'origine dati con le modifiche e infine l'aggiornamento esistente DataTable.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.

Quando si esegue un'operazione di unione, le modifiche apportate ai dati esistenti prima dell'unione vengono conservate durante l'operazione di unione, a meno che lo sviluppatore specifica false per il preserveChanges parametro.When 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. Se il preserveChanges parametro è impostato su true, i valori in ingresso non sovrascrivano i valori esistenti nella versione di riga corrente della riga esistente.If the preserveChanges parameter is set to true, incoming values do not overwrite existing values in the Current row version of the existing row. Se il preserveChanges parametro è impostato su false, i valori in ingresso verranno sovrascritti i valori esistenti nella versione di riga corrente della riga esistente.If the preserveChanges parameter is set to false, incoming values do overwrite the existing values in the Current row version of the existing row. Per altre informazioni sulle versioni delle righe, vedere stati e le versioni delle righe.For more information about row versions, see Row States and Row Versions.

In un'applicazione client, è normale avere un unico pulsante che l'utente può scegliere che raccoglie i dati modificati e la convalida prima di inviarlo a un componente di livello intermedio.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 questo scenario il GetChanges metodo viene richiamato prima di tutto.In this scenario, the GetChanges method is first invoked. Questo metodo restituisce un secondo DataTable ottimizzato per la convalida e l'unione.That method returns a second DataTable optimized for validating and merging. Questa seconda DataTable oggetto contiene solo le DataTable e DataRow oggetti che sono stati modificati, causando un sottoinsieme dell'oggetto originale DataTable.This second DataTable object contains only the DataTable and DataRow objects that were changed, resulting in a subset of the original DataTable. Questo subset è generalmente di dimensioni ridotte e pertanto questo subset è più efficiente passare a un componente di livello intermedio.This subset is generally smaller, and thus this subset is more efficiently passed back to a middle tier component. Il componente di livello intermedio aggiorna quindi l'origine dati originale con le modifiche mediante le stored procedure.The middle tier component then updates the original data source with the changes through stored procedures. Il livello intermedio può quindi inviare un nuovo oggetto DataTable che include dati originali e i dati più recenti dall'origine dati (per eseguire nuovamente la query originale), oppure che venga inviato nuovamente il subset con eventuali modifiche apportate a esso dall'origine dati.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. (Ad esempio, se l'origine dati crea automaticamente i valori di chiave primari univoca, questi valori possono essere propagati all'applicazione client.) In entrambi i casi, l'oggetto restituito DataTable può essere nuovamente uniti in originale dell'applicazione client DataTable con il Merge (metodo).(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.

Durante il merge di una nuova origine DataTable nella destinazione, qualsiasi origine righe con un DataRowState pari a Unchanged, Modified, o Deleted corrispondono alle righe di destinazione con gli stessi valori di chiave primari.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. Origine le righe con un DataRowState pari a Added corrispondono alle nuove righe di destinazione con gli stessi valori di chiave primari come le nuove righe di origine.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.

Vedi anche

Merge(DataTable) Merge(DataTable) Merge(DataTable) Merge(DataTable)

Unire la classe DataTable specificata alla classe DataTable corrente.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)

Parametri

table
DataTable DataTable DataTable DataTable

Classe DataTable da unire alla classe DataTable corrente.The DataTable to be merged with the current DataTable.

Esempi

La seguente applicazione console crea un semplice DataTable e aggiunge i dati alla tabella.The following console application creates a simple DataTable and adds data to the table. L'esempio crea quindi una copia della tabella, l'aggiunta di righe per la copia.The example then creates a copy of the table, adding rows to the copy. Infine, nell'esempio viene chiamato il Merge metodo per unire i dati nella seconda tabella con i dati nella prima tabella.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

Commenti

Il metodo Merge viene utilizzato per unire due DataTable gli oggetti che contengono schemi molto simili.The Merge method is used to merge two DataTable objects that have largely similar schemas. Un'unione nell'indice è in genere usato in un'applicazione client per incorporare le modifiche più recenti da un'origine dati in un oggetto esistente DataTable.A merge is typically used on a client application to incorporate the latest changes from a data source into an existing DataTable. In questo modo l'applicazione client avere un oggetto aggiornato DataTable con i dati più recenti dall'origine dati.This allows the client application to have a refreshed DataTable with the latest data from the data source.

L'operazione di unione prende in considerazione solo la tabella originale e la tabella da unire.The merge operation takes into account only the original table, and the table to be merged. Tabelle figlio non vengono modificate o inclusi.Child tables are not affected or included. Se una tabella include una o più tabelle figlio, definite come parte di una relazione, ogni tabella figlio deve essere unito singolarmente.If a table has one or more child tables, defined as part of a relationship, each child table must be merged individually.

Il Merge viene chiamato in genere alla fine di una serie di procedure che comportano la convalida delle modifiche, la risoluzione degli errori, aggiornare l'origine dati con le modifiche e infine l'aggiornamento esistente DataTable.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.

Quando si esegue un'operazione di unione, le modifiche apportate ai dati esistenti prima dell'unione vengono conservate per impostazione predefinita durante l'operazione di unione.When performing a merge, changes made to the existing data before the merge are preserved by default during the merge operation. Gli sviluppatori possono modificare questo comportamento chiamando uno degli altri due overload per questo metodo, e specificare un valore false per il preserveChanges parametro.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 un'applicazione client, è normale avere un unico pulsante che l'utente può scegliere che raccoglie i dati modificati e la convalida prima di inviarlo a un componente di livello intermedio.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 questo scenario il GetChanges metodo viene richiamato prima di tutto.In this scenario, the GetChanges method is first invoked. Questo metodo restituisce un secondo DataTable ottimizzato per la convalida e l'unione.That method returns a second DataTable optimized for validating and merging. Questa seconda DataTable oggetto contiene solo le DataRow gli oggetti che sono stati modificati, causando un sottoinsieme dell'oggetto originale DataTable.This second DataTable object contains only the DataRow objects that were changed, resulting in a subset of the original DataTable. Questo subset è generalmente più piccoli e di conseguenza in modo più efficiente passato a un componente di livello intermedio.This subset is generally smaller and thus more efficiently passed back to a middle tier component. Il componente di livello intermedio aggiorna quindi l'origine dati originale con le modifiche mediante le stored procedure.The middle tier component then updates the original data source with the changes through stored procedures. Il livello intermedio può quindi inviare un nuovo oggetto DataTable che include dati originali e i dati più recenti dall'origine dati (per eseguire nuovamente la query originale), oppure che venga inviato nuovamente il subset con eventuali modifiche apportate a esso dall'origine dati.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. (Ad esempio, se l'origine dati crea automaticamente i valori di chiave primari univoca, questi valori possono essere propagati all'applicazione client.) In entrambi i casi, l'oggetto restituito DataTable può essere nuovamente uniti in originale dell'applicazione client DataTable con il Merge (metodo).(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.

Durante il merge di una nuova origine DataTable nella destinazione, qualsiasi origine righe con un DataRowState pari a Unchanged, Modified, o Deleted, esiste una corrispondenza per le righe di destinazione con gli stessi valori di chiave primari.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. Origine le righe con un DataRowState pari a Added corrispondono alle nuove righe di destinazione con gli stessi valori di chiave primari come le nuove righe di origine.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.

Vedi anche

Si applica a