DataTable.Merge Método
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Sobrecargas
Merge(DataTable, Boolean, MissingSchemaAction) |
Mescla o DataTable especificado com o |
Merge(DataTable, Boolean) |
Mescla o DataTable especificado com o |
Merge(DataTable) |
Exemplos
O aplicativo de console a seguir 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. Em seguida, o código tenta mesclar a segunda tabela na primeira.
Observação
Este exemplo mostra como usar uma das versões sobrecarregadas da Mesclagem. Para obter outros exemplos que possam estar disponíveis, consulte os tópicos de sobrecarga individuais.
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. Uma mesclagem é normalmente usada em um aplicativo cliente incorporar as alterações mais recentes feitas em uma fonte de dados a um DataTableexistente. Isso permite que o aplicativo cliente tenha um DataTable atualizado com os dados mais recentes a partir da fonte de dados.
A operação de mesclagem leva em conta apenas a tabela original, e a tabela a ser mesclada. As tabelas filho não são afetadas ou incluídas. Se uma tabela tiver uma ou mais tabelas filho, definidas como parte de uma relação, cada tabela filho deverá ser mesclada individualmente.
Merge(DataTable, Boolean, MissingSchemaAction)
- Origem:
- DataTable.cs
- Origem:
- DataTable.cs
- Origem:
- DataTable.cs
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.
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
- missingSchemaAction
- MissingSchemaAction
Um dos valores de MissingSchemaAction.
Exemplos
O aplicativo de console a seguir 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. Em seguida, o código tenta mesclar 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
Comentários
O método Merge
é usado para mesclar dois objetos DataTable que têm esquemas amplamente semelhantes. Uma mesclagem é normalmente usada em um aplicativo cliente incorporar as alterações mais recentes feitas em uma fonte de dados a um DataTableexistente. Isso permite que o aplicativo cliente tenha um DataTable atualizado com os dados mais recentes a partir da fonte de dados.
A operação de mesclagem leva em conta apenas a tabela original, e a tabela a ser mesclada. As tabelas filho não são afetadas ou incluídas. Se uma tabela tiver uma ou mais tabelas filho, definidas como parte de uma relação, cada tabela filho deverá ser mesclada individualmente.
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.
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 preserveChanges
parâmetro . Se o preserveChanges
parâmetro for definido como true
, os valores de entrada não substituirão os valores existentes na versão de linha atual da linha existente. Se o preserveChanges
parâmetro for definido como false
, os valores de entrada substituirão os valores existentes na versão de linha atual da linha existente. Para obter mais informações sobre versões de linha, consulte Estados de linha e versões de linha.
Em um aplicativo cliente, é comum ter um único botão que 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. Nesse cenário, o método GetChanges é invocado primeiro. O método retorna um segundo DataTable otimizado para validação e mesclagem. Este segundo objeto DataTable contém apenas os objetos DataTable e DataRow que foram modificados, resultando em um subconjunto do DataTable original. Esse subconjunto geralmente é menor e, portanto, esse subconjunto é mais eficientemente passado de volta para um componente de camada intermediária. Em seguida, o componente da camada intermediária atualiza a fonte de dados original com as alterações por meio de procedimentos armazenados. 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. (Por exemplo, se a fonte de dados criar automaticamente valores de chave primária exclusivos, esses valores poderão ser propagados de volta para o aplicativo cliente.) Em ambos os casos, o retornado DataTable pode ser mesclado de volta ao original DataTable do aplicativo 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 possam ter sido alterados. Por exemplo, em um cenário entre empresas, novas colunas podem ter sido adicionadas a um esquema XML por um processo automatizado. 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
. Nesse caso, o DataTable mesclado contém o esquema e os dados adicionados.
Após a mesclagem de esquemas, os dados são mesclados.
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. 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.
Confira também
Aplica-se a
Merge(DataTable, Boolean)
- Origem:
- DataTable.cs
- Origem:
- DataTable.cs
- Origem:
- DataTable.cs
Mescla o DataTable especificado com o DataTable
atual, indicando se as alterações no DataTable
atual devem ser preservadas.
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.
- preserveChanges
- Boolean
true
, para preservar alterações no DataTable
atual; caso contrário, false
.
Exemplos
O aplicativo de console a seguir cria uma DataTable que contém linhas, modifica alguns dos dados nessas linhas e tenta mesclar dados de um diferente DataTable. 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
Comentários
O método Merge é usado para mesclar dois DataTable objetos que têm esquemas amplamente semelhantes. Uma mesclagem é normalmente usada em um aplicativo cliente incorporar as alterações mais recentes feitas em uma fonte de dados a um DataTableexistente. Isso permite que o aplicativo cliente tenha um DataTable atualizado com os dados mais recentes a partir da fonte de dados.
A operação de mesclagem leva em conta apenas a tabela original, e a tabela a ser mesclada. As tabelas filho não são afetadas ou incluídas. Se uma tabela tiver uma ou mais tabelas filho, definidas como parte de uma relação, cada tabela filho deverá ser mesclada individualmente.
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.
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 preserveChanges
parâmetro . Se o preserveChanges
parâmetro for definido como true
, os valores de entrada não substituirão os valores existentes na versão de linha atual da linha existente. Se o preserveChanges
parâmetro for definido como false
, os valores de entrada substituirão os valores existentes na versão de linha atual da linha existente. Para obter mais informações sobre versões de linha, consulte Estados de linha e versões de linha.
Em um aplicativo cliente, é comum ter um único botão que 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. Nesse cenário, o método GetChanges é invocado primeiro. O método retorna um segundo DataTable otimizado para validação e mesclagem. Este segundo objeto DataTable contém apenas os objetos DataTable e DataRow que foram modificados, resultando em um subconjunto do DataTable original. Esse subconjunto geralmente é menor e, portanto, esse subconjunto é mais eficientemente passado de volta para um componente de camada intermediária. Em seguida, o componente da camada intermediária atualiza a fonte de dados original com as alterações por meio de procedimentos armazenados. 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. (Por exemplo, se a fonte de dados criar automaticamente valores de chave primária exclusivos, esses valores poderão ser propagados de volta para o aplicativo cliente.) Em ambos os casos, o retornado DataTable pode ser mesclado de volta ao original DataTable do aplicativo cliente com o Merge método .
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. 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.
Confira também
Aplica-se a
Merge(DataTable)
- Origem:
- DataTable.cs
- Origem:
- DataTable.cs
- Origem:
- DataTable.cs
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
Exemplos
O aplicativo de console a seguir cria um simples DataTable e adiciona dados à tabela. Em seguida, o exemplo cria uma cópia da tabela, adicionando linhas à cópia. Por fim, o exemplo chama o Merge método para mesclar os dados na segunda tabela com os dados na 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
Comentários
O método Merge é usado para mesclar dois DataTable objetos que têm esquemas amplamente semelhantes. Uma mesclagem é normalmente usada em um aplicativo cliente incorporar as alterações mais recentes feitas em uma fonte de dados a um DataTableexistente. Isso permite que o aplicativo cliente tenha um DataTable atualizado com os dados mais recentes a partir da fonte de dados.
A operação de mesclagem leva em conta apenas a tabela original, e a tabela a ser mesclada. As tabelas filho não são afetadas ou incluídas. Se uma tabela tiver uma ou mais tabelas filho, definidas como parte de uma relação, cada tabela filho deverá ser mesclada individualmente.
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.
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. Os desenvolvedores podem modificar esse comportamento chamando uma das outras duas sobrecargas para esse método e especificando um valor falso para o preserveChanges
parâmetro .
Em um aplicativo cliente, é comum ter um único botão que 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. Nesse cenário, o método GetChanges é invocado primeiro. O método retorna um segundo DataTable otimizado para validação e mesclagem. Este segundo DataTable objeto contém apenas os DataRow objetos que foram alterados, resultando em um subconjunto do original DataTable. Esse subconjunto geralmente é menor e, portanto, mais eficientemente passado de volta para um componente de camada intermediária. Em seguida, o componente da camada intermediária atualiza a fonte de dados original com as alterações por meio de procedimentos armazenados. 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. (Por exemplo, se a fonte de dados criar automaticamente valores de chave primária exclusivos, esses valores poderão ser propagados de volta para o aplicativo cliente.) Em ambos os casos, o retornado DataTable pode ser mesclado de volta ao original DataTable do aplicativo cliente com o Merge método .
Ao mesclar uma nova fonte DataTable no destino, todas as linhas de origem com um DataRowState valor de Unchanged
, Modified
ou Deleted
, são correspondidas às linhas de destino com os mesmos valores de chave primária. 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.