DataTable.Merge Método

Definição

Funde o especificado DataTable com a corrente DataTable.

Sobrecargas

Name Description
Merge(DataTable, Boolean, MissingSchemaAction)

Juntar o especificado DataTable com o atual DataTable, indicando se deve preservar as alterações e como lidar com o esquema em falta no atual DataTable.

Merge(DataTable, Boolean)

Fuja o especificado DataTable com a corrente DataTable, indicando se deve preservar as alterações na corrente DataTable.

Merge(DataTable)

Funde o especificado DataTable com a corrente DataTable.

Exemplos

A aplicação de consola seguinte demonstra o comportamento do missingSchemaAction parâmetro do Merge método. Este exemplo cria duas versões da mesma tabela, modificando o esquema para a segunda versão. O código tenta então fundir a segunda tabela na primeira.

Note

Este exemplo mostra como usar uma das versões sobrecarregadas do Merge. Para outros exemplos que possam estar disponíveis, veja os tópicos individuais de sobrecarga.

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

Observações

O Merge método é usado para fundir dois DataTable objetos que têm esquemas em grande parte semelhantes. Uma fusão é tipicamente usada numa aplicação cliente para incorporar as alterações mais recentes de uma fonte de dados numa aplicação existente DataTable. Isto permite que a aplicação cliente seja atualizada DataTable com os dados mais recentes da fonte de dados.

A operação de fusão tem em conta apenas a tabela original e a tabela a ser fundida. As mesas infantis não são afetadas nem incluídas. Se uma tabela tiver uma ou mais tabelas filhas, definidas como parte de uma relação, cada tabela filha deve ser fundida individualmente.

Merge(DataTable, Boolean, MissingSchemaAction)

Juntar o especificado DataTable com o atual DataTable, indicando se deve preservar as alterações e como lidar com o esquema em falta no atual 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 para ser fundido com a corrente DataTable.

preserveChanges
Boolean

true, para preservar as alterações na corrente DataTable; caso contrário false.

missingSchemaAction
MissingSchemaAction

Um dos MissingSchemaAction valores.

Exemplos

A aplicação de consola seguinte demonstra o comportamento do missingSchemaAction parâmetro do Merge método. Este exemplo cria duas versões da mesma tabela, modificando o esquema para a segunda versão. O código tenta então fundir a segunda tabela na primeira.

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

Observações

O Merge método é usado para fundir dois DataTable objetos que têm esquemas em grande parte semelhantes. Uma fusão é tipicamente usada numa aplicação cliente para incorporar as alterações mais recentes de uma fonte de dados numa aplicação existente DataTable. Isto permite que a aplicação cliente seja atualizada DataTable com os dados mais recentes da fonte de dados.

A operação de fusão tem em conta apenas a tabela original e a tabela a ser fundida. As mesas infantis não são afetadas nem incluídas. Se uma tabela tiver uma ou mais tabelas filhas, definidas como parte de uma relação, cada tabela filha deve ser fundida individualmente.

O Merge método é normalmente chamado no final de uma série de procedimentos que envolvem validar alterações, reconciliar erros, atualizar a fonte de dados com as alterações e, finalmente, atualizar o .DataTable

Ao realizar uma fusão, as alterações feitas aos dados existentes antes da fusão são preservadas durante a operação, a menos que o programador especifique false para o preserveChanges parâmetro. Se o preserveChanges parâmetro estiver definido para true, os valores recebidos não sobrescrevem valores existentes na versão da linha atual da linha existente. Se o preserveChanges parâmetro estiver definido para false, os valores recebidos sobrescrevem os valores existentes na versão da linha atual da linha existente. Para obter mais informações sobre versões de linha, consulte Estados de linha e versões de linha.

Numa aplicação cliente, é habitual ter um único botão que o utilizador pode clicar, que recolhe os dados alterados e os valida antes de os enviar de volta para um componente de nível intermédio. Neste cenário, o GetChanges método é primeiro invocado. Esse método devolve um segundo DataTable otimizado para validação e fusão. Este segundo DataTable objeto contém apenas os DataTable objetos e DataRow que foram alterados, resultando num subconjunto do original DataTable. Este subconjunto é geralmente mais pequeno e, por isso, é mais eficientemente passado de volta para um componente de nível intermédio. O componente de nível intermédio atualiza então a fonte de dados original com as alterações através de procedimentos armazenados. O nível intermédio pode então enviar de volta um novo DataTable que inclua os dados originais e os dados mais recentes da fonte de dados (executando novamente a consulta original), ou pode enviar de volta o subconjunto com quaisquer alterações feitas a partir da fonte de dados. (Por exemplo, se a fonte de dados criar automaticamente valores únicos de chave primária, esses valores podem ser propagados de volta para a aplicação cliente.) Em qualquer dos casos, os devolvidos DataTable podem ser fundidos novamente no original DataTable da aplicação cliente com o Merge método.

Quando o Merge método é chamado, os esquemas dos dois DataTable objetos são comparados, pois é possível que os esquemas tenham sido alterados. Por exemplo, num cenário business-to-business, novas colunas podem ter sido adicionadas a um esquema XML por um processo automatizado. Se a fonte DataTable contiver elementos de esquema (objetos adicionados DataColumn ) que estão em falta no destino, os elementos do esquema podem ser adicionados ao destino definindo o missingSchemaAction argumento para MissingSchemaAction.Add. Nesse caso, a fusão DataTable contém o esquema e os dados adicionados.

Após a fusão dos esquemas, os dados são fundidos.

Ao fundir uma nova fonte DataTable no destino, quaisquer linhas de origem com DataRowState valor de Unchanged, Modified, ou Deleted são associadas a linhas alvo com os mesmos valores de chave primária. As linhas de origem com um DataRowState valor de Added são emparelhadas com novas linhas de destino com os mesmos valores de chave primária que as novas linhas de origem.

Ver também

Aplica-se a

Merge(DataTable, Boolean)

Fuja o especificado DataTable com a corrente DataTable, indicando se deve preservar as alterações na corrente 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 para ser fundido com a corrente DataTable.

preserveChanges
Boolean

true, para preservar as alterações na corrente DataTable; caso contrário false.

Exemplos

A aplicação de consola seguinte cria linhas DataTable contendo, modifica alguns dos dados nessas linhas e tenta fundir dados de diferentes DataTablelinhas . O exemplo demonstra os diferentes comportamentos do preserveChanges parâmetro.


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

Observações

O método Merge é usado para fundir dois DataTable objetos que têm esquemas largamente semelhantes. Uma fusão é tipicamente usada numa aplicação cliente para incorporar as alterações mais recentes de uma fonte de dados numa aplicação existente DataTable. Isto permite que a aplicação cliente seja atualizada DataTable com os dados mais recentes da fonte de dados.

A operação de fusão tem em conta apenas a tabela original e a tabela a ser fundida. As mesas infantis não são afetadas nem incluídas. Se uma tabela tiver uma ou mais tabelas filhas, definidas como parte de uma relação, cada tabela filha deve ser fundida individualmente.

O Merge método é normalmente chamado no final de uma série de procedimentos que envolvem validar alterações, reconciliar erros, atualizar a fonte de dados com as alterações e, finalmente, atualizar o .DataTable

Ao realizar uma fusão, as alterações feitas aos dados existentes antes da fusão são preservadas durante a operação, a menos que o programador especifique false para o preserveChanges parâmetro. Se o preserveChanges parâmetro estiver definido para true, os valores recebidos não sobrescrevem valores existentes na versão da linha atual da linha existente. Se o preserveChanges parâmetro estiver definido para false, os valores recebidos sobrescrevem os valores existentes na versão da linha atual da linha existente. Para obter mais informações sobre versões de linha, consulte Estados de linha e versões de linha.

Numa aplicação cliente, é habitual ter um único botão que o utilizador pode clicar, que recolhe os dados alterados e os valida antes de os enviar de volta para um componente de nível intermédio. Neste cenário, o GetChanges método é primeiro invocado. Esse método devolve um segundo DataTable otimizado para validação e fusão. Este segundo DataTable objeto contém apenas os DataTable objetos e DataRow que foram alterados, resultando num subconjunto do original DataTable. Este subconjunto é geralmente mais pequeno e, por isso, é mais eficientemente passado de volta para um componente de nível intermédio. O componente de nível intermédio atualiza então a fonte de dados original com as alterações através de procedimentos armazenados. O nível intermédio pode então enviar de volta um novo DataTable que inclua os dados originais e os dados mais recentes da fonte de dados (executando novamente a consulta original), ou pode enviar de volta o subconjunto com quaisquer alterações feitas a partir da fonte de dados. (Por exemplo, se a fonte de dados criar automaticamente valores únicos de chave primária, esses valores podem ser propagados de volta para a aplicação cliente.) Em qualquer dos casos, os devolvidos DataTable podem ser fundidos novamente no original DataTable da aplicação cliente com o Merge método.

Ao fundir uma nova fonte DataTable no destino, quaisquer linhas de origem com DataRowState valor de Unchanged, Modified, ou Deleted são associadas a linhas alvo com os mesmos valores de chave primária. As linhas de origem com um DataRowState valor de Added são emparelhadas com novas linhas de destino com os mesmos valores de chave primária que as novas linhas de origem.

Ver também

Aplica-se a

Merge(DataTable)

Funde o especificado DataTable com a corrente 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 para ser fundido com a corrente DataTable.

Exemplos

A aplicação de consola seguinte cria um simples DataTable e adiciona dados à tabela. O exemplo cria então uma cópia da tabela, adicionando linhas à cópia. Finalmente, o exemplo chama o Merge método para fundir os dados da segunda tabela com os dados da primeira tabela.

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

Observações

O método Merge é usado para fundir dois DataTable objetos que têm esquemas largamente semelhantes. Uma fusão é tipicamente usada numa aplicação cliente para incorporar as alterações mais recentes de uma fonte de dados numa aplicação existente DataTable. Isto permite que a aplicação cliente seja atualizada DataTable com os dados mais recentes da fonte de dados.

A operação de fusão tem em conta apenas a tabela original e a tabela a ser fundida. As mesas infantis não são afetadas nem incluídas. Se uma tabela tiver uma ou mais tabelas filhas, definidas como parte de uma relação, cada tabela filha deve ser fundida individualmente.

O Merge método é normalmente chamado no final de uma série de procedimentos que envolvem validar alterações, reconciliar erros, atualizar a fonte de dados com as alterações e, finalmente, atualizar o .DataTable

Ao realizar uma fusão, as alterações feitas aos dados existentes antes da fusão são preservadas por defeito durante a operação. Os programadores podem modificar este comportamento chamando uma das outras duas sobrecargas deste método e especificando um valor falso para o preserveChanges parâmetro.

Numa aplicação cliente, é habitual ter um único botão que o utilizador pode clicar, que recolhe os dados alterados e os valida antes de os enviar de volta para um componente de nível intermédio. Neste cenário, o GetChanges método é primeiro invocado. Esse método devolve um segundo DataTable otimizado para validação e fusão. Este segundo DataTable objeto contém apenas os DataRow objetos que foram alterados, resultando num subconjunto do original DataTable. Este subconjunto é geralmente mais pequeno e, por isso, é mais eficientemente passado de volta para um componente de nível intermédio. O componente de nível intermédio atualiza então a fonte de dados original com as alterações através de procedimentos armazenados. O nível intermédio pode então enviar de volta um novo DataTable que inclua os dados originais e os dados mais recentes da fonte de dados (executando novamente a consulta original), ou pode enviar de volta o subconjunto com quaisquer alterações feitas a partir da fonte de dados. (Por exemplo, se a fonte de dados criar automaticamente valores únicos de chave primária, esses valores podem ser propagados de volta para a aplicação cliente.) Em qualquer dos casos, os devolvidos DataTable podem ser fundidos novamente no original DataTable da aplicação cliente com o Merge método.

Ao fundir uma nova fonte DataTable no alvo, quaisquer linhas de origem com DataRowState valor de Unchanged, Modified, ou Deleted, são associadas a linhas alvo com os mesmos valores de chave primária. As linhas de origem com um DataRowState valor de Added são emparelhadas com novas linhas de destino com os mesmos valores de chave primária que as novas linhas de origem.

Ver também

Aplica-se a