DataTable.Merge Método

Definição

Mesclar o DataTable especificado ao DataTable atual.Merge the specified DataTable with the current DataTable.

Sobrecargas

Merge(DataTable, Boolean, MissingSchemaAction)

Mescla o DataTable especificado com o DataTable atual, indicando se as alterações e a maneira como manipular o esquema ausente no DataTable atual devem ser preservadas.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)

Mescla o DataTable especificado com o DataTable atual, indicando se as alterações no DataTable atual devem ser preservadas.Merge the specified DataTable with the current DataTable, indicating whether to preserve changes in the current DataTable.

Merge(DataTable)

Mesclar o DataTable especificado ao DataTable atual.Merge the specified DataTable with the current DataTable.

Exemplos

O aplicativo de console a seguir demonstra o comportamento do parâmetro missingSchemaAction do método Merge.The following console application demonstrates the behavior of the missingSchemaAction parameter of the Merge method. Este exemplo cria duas versões da mesma tabela, modificando o esquema para a segunda versão.This example creates two versions of the same table, modifying the schema for the second version. Em seguida, o código tenta mesclar a segunda tabela no primeiro.The code then attempts to merge the second table into the first.

Observação

Este exemplo mostra como usar uma das versões sobrecarregadas da mesclagem.This example shows how to use one of the overloaded versions of Merge. Para obter outros exemplos que possam estar disponíveis, consulte os tópicos de sobrecarga individuais.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

Comentários

O método Merge é usado para mesclar dois objetos DataTable que têm esquemas amplamente semelhantes.The Merge method is used to merge two DataTable objects that have largely similar schemas. Uma mesclagem é normalmente usada em um aplicativo cliente incorporar as alterações mais recentes feitas em uma fonte de dados a um DataTableexistente.A merge is typically used on a client application to incorporate the latest changes from a data source into an existing DataTable. Isso permite que o aplicativo cliente tenha um DataTable atualizado com os dados mais recentes a partir da fonte de dados.This allows the client application to have a refreshed DataTable with the latest data from the data source.

A operação de mesclagem leva em conta apenas a tabela original, e a tabela a ser mesclada.The merge operation takes into account only the original table, and the table to be merged. As tabelas filho não são afetadas ou incluídas.Child tables are not affected or included. Se uma tabela tiver uma ou mais tabelas filho, definidas como parte de uma relação, cada tabela filho deverá ser mesclada individualmente.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)

Mescla o DataTable especificado com o DataTable atual, indicando se as alterações e a maneira como manipular o esquema ausente no DataTable atual devem ser preservadas.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
Public Sub Merge (table As DataTable, preserveChanges As Boolean, missingSchemaAction As MissingSchemaAction)

Parâmetros

table
DataTable

O DataTable a ser mesclado com o DataTable atual.The DataTable to be merged with the current DataTable.

preserveChanges
Boolean

true, para preservar alterações no DataTable atual; caso contrário, false.true, to preserve changes in the current DataTable; otherwise false.

missingSchemaAction
MissingSchemaAction

Um dos valores de MissingSchemaAction.One of the MissingSchemaAction values.

Exemplos

O aplicativo de console a seguir demonstra o comportamento do parâmetro missingSchemaAction do método Merge.The following console application demonstrates the behavior of the missingSchemaAction parameter of the Merge method. Este exemplo cria duas versões da mesma tabela, modificando o esquema para a segunda versão.This example creates two versions of the same table, modifying the schema for the second version. Em seguida, o código tenta mesclar a segunda tabela no primeiro.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

Comentários

O método Merge é usado para mesclar dois objetos DataTable que têm esquemas amplamente semelhantes.The Merge method is used to merge two DataTable objects that have largely similar schemas. Uma mesclagem é normalmente usada em um aplicativo cliente incorporar as alterações mais recentes feitas em uma fonte de dados a um DataTableexistente.A merge is typically used on a client application to incorporate the latest changes from a data source into an existing DataTable. Isso permite que o aplicativo cliente tenha um DataTable atualizado com os dados mais recentes a partir da fonte de dados.This allows the client application to have a refreshed DataTable with the latest data from the data source.

A operação de mesclagem leva em conta apenas a tabela original, e a tabela a ser mesclada.The merge operation takes into account only the original table, and the table to be merged. As tabelas filho não são afetadas ou incluídas.Child tables are not affected or included. Se uma tabela tiver uma ou mais tabelas filho, definidas como parte de uma relação, cada tabela filho deverá ser mesclada individualmente.If a table has one or more child tables, defined as part of a relationship, each child table must be merged individually.

O método Merge é chamado geralmente ao final de uma série de procedimentos que envolvem a validação de alterações, a reconciliação de erros, a atualização da fonte de dados com as alterações e, por fim, a atualização do DataTableexistente.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.

Ao executar uma mesclagem, as alterações feitas nos dados existentes antes da mesclagem são preservadas durante a operação de mesclagem, a menos que o desenvolvedor especifique false para o parâmetro preserveChanges.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 o parâmetro preserveChanges for definido como true, os valores de entrada não substituirão os valores existentes na versão da linha atual da linha existente.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 o parâmetro preserveChanges for definido como false, os valores de entrada substituirão os valores existentes na versão da linha atual da linha existente.If the preserveChanges parameter is set to false, incoming values do overwrite the existing values in the Current row version of the existing row. Para obter mais informações sobre versões de linha, consulte Estados de linha e versões de linha.For more information about row versions, see Row States and Row Versions.

Em um aplicativo cliente, é comum ter um único botão no qual o usuário possa clicar para coletar os dados alterados e validá-los antes de enviá-los de volta para um componente de camada intermediária.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. Nesse cenário, o método GetChanges é invocado primeiro.In this scenario, the GetChanges method is first invoked. O método retorna um segundo DataTable otimizado para validação e mesclagem.That method returns a second DataTable optimized for validating and merging. Este segundo objeto DataTable contém apenas os objetos DataTable e DataRow que foram modificados, resultando em um subconjunto do DataTable original.This second DataTable object contains only the DataTable and DataRow objects that were changed, resulting in a subset of the original DataTable. Esse subconjunto é geralmente menor e, portanto, esse subconjunto é passado de volta com mais eficiência para um componente de camada intermediária.This subset is generally smaller, and thus this subset is more efficiently passed back to a middle tier component. Em seguida, o componente de camada intermediária atualiza a fonte de dados original com as alterações por meio de procedimentos armazenados.The middle tier component then updates the original data source with the changes through stored procedures. A camada intermediária pode enviar novamente em qualquer um novo DataTable que inclui dados originais e os dados mais recentes da fonte de dados (executando a consulta original novamente), ou pode enviar novamente o subconjunto com eventuais alterações feitas a partir da fonte de dados.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. (Por exemplo, se a fonte de dados cria automaticamente valores exclusivos de chave primária, esses valores podem ser propagados de volta para o aplicativo cliente.) Em ambos os casos, o DataTable retornado pode ser mesclado novamente no DataTable original do aplicativo cliente com o método Merge.(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 o método de Merge é chamado, os esquemas dos dois objetos DataTable são comparados, pois é possível que os esquemas tenham sido alterados.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. Por exemplo, em um cenário entre empresas, novas colunas podem ter sido adicionadas a um esquema XML por um processo automatizado.For example, in a business-to-business scenario, new columns may have been added to an XML schema by an automated process. Se a fonte DataTable contiver elementos do esquema (objetos DataColumn adicionados) que estão faltando no destino, os elementos do esquema poderão ser adicionados ao destino definindo o argumento missingSchemaAction como 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. Nesse caso, o DataTable mesclado contém o esquema e os dados adicionados.In that case, the merged DataTable contains the added schema and data.

Após a mesclagem de esquemas, os dados são mesclados.After merging schemas, the data is merged.

Durante a mesclagem de uma nova fonte DataTable no destino, qualquer linha de origem com um valor DataRowState de Unchanged, Modified ou Deleted são correspondidos para selecionar linhas com os mesmos valores de chave primária.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. As linhas de origem com um valor de DataRowState de Added correspondem às novas linhas de destino com os mesmos valores de chave primária das novas linhas de origem.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.

Veja também

Merge(DataTable, Boolean)

Mescla o DataTable especificado com o DataTable atual, indicando se as alterações no DataTable atual devem ser preservadas.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)

Parâmetros

table
DataTable

O DataTable a ser mesclado com o DataTable atual.The DataTable to be merged with the current DataTable.

preserveChanges
Boolean

true, para preservar alterações no DataTable atual; caso contrário, false.true, to preserve changes in the current DataTable; otherwise false.

Exemplos

O aplicativo de console a seguir cria um DataTable contendo linhas, modifica alguns dos dados nessas linhas e tenta mesclar dados de um DataTablediferente.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. O exemplo demonstra os diferentes comportamentos para o parâmetro preserveChanges.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(table1Copy, "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(table1Copy, "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

Comentários

O método Merge é usado para mesclar dois objetos DataTable que têm esquemas amplamente semelhantes.The Merge method is used to merge two DataTable objects that have largely similar schemas. Uma mesclagem é normalmente usada em um aplicativo cliente incorporar as alterações mais recentes feitas em uma fonte de dados a um DataTableexistente.A merge is typically used on a client application to incorporate the latest changes from a data source into an existing DataTable. Isso permite que o aplicativo cliente tenha um DataTable atualizado com os dados mais recentes a partir da fonte de dados.This allows the client application to have a refreshed DataTable with the latest data from the data source.

A operação de mesclagem leva em conta apenas a tabela original, e a tabela a ser mesclada.The merge operation takes into account only the original table, and the table to be merged. As tabelas filho não são afetadas ou incluídas.Child tables are not affected or included. Se uma tabela tiver uma ou mais tabelas filho, definidas como parte de uma relação, cada tabela filho deverá ser mesclada individualmente.If a table has one or more child tables, defined as part of a relationship, each child table must be merged individually.

O método Merge é chamado geralmente ao final de uma série de procedimentos que envolvem a validação de alterações, a reconciliação de erros, a atualização da fonte de dados com as alterações e, por fim, a atualização do DataTableexistente.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.

Ao executar uma mesclagem, as alterações feitas nos dados existentes antes da mesclagem são preservadas durante a operação de mesclagem, a menos que o desenvolvedor especifique false para o parâmetro preserveChanges.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 o parâmetro preserveChanges for definido como true, os valores de entrada não substituirão os valores existentes na versão da linha atual da linha existente.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 o parâmetro preserveChanges for definido como false, os valores de entrada substituirão os valores existentes na versão da linha atual da linha existente.If the preserveChanges parameter is set to false, incoming values do overwrite the existing values in the Current row version of the existing row. Para obter mais informações sobre versões de linha, consulte Estados de linha e versões de linha.For more information about row versions, see Row States and Row Versions.

Em um aplicativo cliente, é comum ter um único botão no qual o usuário possa clicar para coletar os dados alterados e validá-los antes de enviá-los de volta para um componente de camada intermediária.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. Nesse cenário, o método GetChanges é invocado primeiro.In this scenario, the GetChanges method is first invoked. O método retorna um segundo DataTable otimizado para validação e mesclagem.That method returns a second DataTable optimized for validating and merging. Este segundo objeto DataTable contém apenas os objetos DataTable e DataRow que foram modificados, resultando em um subconjunto do DataTable original.This second DataTable object contains only the DataTable and DataRow objects that were changed, resulting in a subset of the original DataTable. Esse subconjunto é geralmente menor e, portanto, esse subconjunto é passado de volta com mais eficiência para um componente de camada intermediária.This subset is generally smaller, and thus this subset is more efficiently passed back to a middle tier component. Em seguida, o componente de camada intermediária atualiza a fonte de dados original com as alterações por meio de procedimentos armazenados.The middle tier component then updates the original data source with the changes through stored procedures. A camada intermediária pode enviar novamente em qualquer um novo DataTable que inclui dados originais e os dados mais recentes da fonte de dados (executando a consulta original novamente), ou pode enviar novamente o subconjunto com eventuais alterações feitas a partir da fonte de dados.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. (Por exemplo, se a fonte de dados cria automaticamente valores exclusivos de chave primária, esses valores podem ser propagados de volta para o aplicativo cliente.) Em ambos os casos, o DataTable retornado pode ser mesclado novamente no DataTable original do aplicativo cliente com o método Merge.(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 a mesclagem de uma nova fonte DataTable no destino, qualquer linha de origem com um valor DataRowState de Unchanged, Modified ou Deleted são correspondidos para selecionar linhas com os mesmos valores de chave primária.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. As linhas de origem com um valor de DataRowState de Added correspondem às novas linhas de destino com os mesmos valores de chave primária das novas linhas de origem.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.

Veja também

Merge(DataTable)

Mesclar o DataTable especificado ao DataTable atual.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)

Parâmetros

table
DataTable

O DataTable a ser mesclado com o DataTable atual.The DataTable to be merged with the current DataTable.

Exemplos

O aplicativo de console a seguir cria um DataTable simples e adiciona dados à tabela.The following console application creates a simple DataTable and adds data to the table. Em seguida, o exemplo cria uma cópia da tabela, adicionando linhas à cópia.The example then creates a copy of the table, adding rows to the copy. Por fim, o exemplo chama o método Merge para mesclar os dados na segunda tabela com os dados na primeira tabela.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

Comentários

O método Merge é usado para mesclar dois objetos DataTable que têm esquemas amplamente semelhantes.The Merge method is used to merge two DataTable objects that have largely similar schemas. Uma mesclagem é normalmente usada em um aplicativo cliente incorporar as alterações mais recentes feitas em uma fonte de dados a um DataTableexistente.A merge is typically used on a client application to incorporate the latest changes from a data source into an existing DataTable. Isso permite que o aplicativo cliente tenha um DataTable atualizado com os dados mais recentes a partir da fonte de dados.This allows the client application to have a refreshed DataTable with the latest data from the data source.

A operação de mesclagem leva em conta apenas a tabela original, e a tabela a ser mesclada.The merge operation takes into account only the original table, and the table to be merged. As tabelas filho não são afetadas ou incluídas.Child tables are not affected or included. Se uma tabela tiver uma ou mais tabelas filho, definidas como parte de uma relação, cada tabela filho deverá ser mesclada individualmente.If a table has one or more child tables, defined as part of a relationship, each child table must be merged individually.

O método Merge é chamado geralmente ao final de uma série de procedimentos que envolvem a validação de alterações, a reconciliação de erros, a atualização da fonte de dados com as alterações e, por fim, a atualização do DataTableexistente.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.

Ao executar uma mesclagem, as alterações feitas nos dados existentes antes da mesclagem são preservadas por padrão durante a operação de mesclagem.When performing a merge, changes made to the existing data before the merge are preserved by default during the merge operation. Os desenvolvedores podem modificar esse comportamento chamando uma das outras duas sobrecargas para esse método e especificando um valor falso para o parâmetro preserveChanges.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.

Em um aplicativo cliente, é comum ter um único botão no qual o usuário possa clicar para coletar os dados alterados e validá-los antes de enviá-los de volta para um componente de camada intermediária.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. Nesse cenário, o método GetChanges é invocado primeiro.In this scenario, the GetChanges method is first invoked. O método retorna um segundo DataTable otimizado para validação e mesclagem.That method returns a second DataTable optimized for validating and merging. Este segundo DataTable objeto contém apenas os objetos DataRow que foram alterados, resultando em um subconjunto da DataTableoriginal.This second DataTable object contains only the DataRow objects that were changed, resulting in a subset of the original DataTable. Esse subconjunto é geralmente menor e, portanto, passado de volta para um componente de camada intermediária.This subset is generally smaller and thus more efficiently passed back to a middle tier component. Em seguida, o componente de camada intermediária atualiza a fonte de dados original com as alterações por meio de procedimentos armazenados.The middle tier component then updates the original data source with the changes through stored procedures. A camada intermediária pode enviar novamente em qualquer um novo DataTable que inclui dados originais e os dados mais recentes da fonte de dados (executando a consulta original novamente), ou pode enviar novamente o subconjunto com eventuais alterações feitas a partir da fonte de dados.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. (Por exemplo, se a fonte de dados cria automaticamente valores exclusivos de chave primária, esses valores podem ser propagados de volta para o aplicativo cliente.) Em ambos os casos, o DataTable retornado pode ser mesclado novamente no DataTable original do aplicativo cliente com o método Merge.(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.

Ao mesclar um novo DataTable de origem no destino, todas as linhas de origem com um valor de DataRowState de Unchanged, Modifiedou Deleted, são correspondidas às linhas de destino com os mesmos valores de chave primária.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. As linhas de origem com um valor de DataRowState de Added correspondem às novas linhas de destino com os mesmos valores de chave primária das novas linhas de origem.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.

Veja também

Aplica-se a