DataTable.Merge Methode
Definitie
Belangrijk
Bepaalde informatie heeft betrekking op een voorlopige productversie die aanzienlijk kan worden gewijzigd voordat deze wordt uitgebracht. Microsoft biedt geen enkele expliciete of impliciete garanties met betrekking tot de informatie die hier wordt verstrekt.
Overloads
| Name | Description |
|---|---|
| Merge(DataTable, Boolean, MissingSchemaAction) |
Voeg de opgegeven DataTable samen met de huidige |
| Merge(DataTable, Boolean) |
Voeg de opgegeven DataTable samen met de huidige |
| Merge(DataTable) |
Voorbeelden
In de volgende consoletoepassing ziet u het gedrag van de missingSchemaAction parameter van de Merge methode. In dit voorbeeld worden twee versies van dezelfde tabel gemaakt, waarbij het schema voor de tweede versie wordt gewijzigd. De code probeert vervolgens de tweede tabel samen te voegen in de eerste.
Note
In dit voorbeeld ziet u hoe u een van de overbelaste versies van Merge gebruikt. Zie de onderwerpen over overbelasting voor afzonderlijke overbelasting voor andere voorbeelden die mogelijk beschikbaar zijn.
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
Opmerkingen
De Merge methode wordt gebruikt voor het samenvoegen van twee DataTable objecten met grotendeels vergelijkbare schema's. Een samenvoeging wordt meestal gebruikt voor een clienttoepassing om de meest recente wijzigingen van een gegevensbron op te nemen in een bestaande DataTable. Hierdoor kan de clienttoepassing worden vernieuwd DataTable met de meest recente gegevens uit de gegevensbron.
Bij de samenvoegbewerking wordt alleen rekening gehouden met de oorspronkelijke tabel en de tabel die moet worden samengevoegd. Onderliggende tabellen worden niet beïnvloed of opgenomen. Als een tabel een of meer onderliggende tabellen bevat, gedefinieerd als onderdeel van een relatie, moet elke onderliggende tabel afzonderlijk worden samengevoegd.
Merge(DataTable, Boolean, MissingSchemaAction)
- Bron:
- DataTable.cs
- Bron:
- DataTable.cs
- Bron:
- DataTable.cs
- Bron:
- DataTable.cs
- Bron:
- DataTable.cs
Voeg de opgegeven DataTable samen met de huidige DataTable, waarmee wordt aangegeven of wijzigingen moeten worden behouden en hoe ontbrekend schema in de huidige DataTablemoet worden verwerkt.
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)
Parameters
- missingSchemaAction
- MissingSchemaAction
Een van de MissingSchemaAction waarden.
Voorbeelden
In de volgende consoletoepassing ziet u het gedrag van de missingSchemaAction parameter van de Merge methode. In dit voorbeeld worden twee versies van dezelfde tabel gemaakt, waarbij het schema voor de tweede versie wordt gewijzigd. De code probeert vervolgens de tweede tabel samen te voegen in de eerste.
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
Opmerkingen
De Merge methode wordt gebruikt voor het samenvoegen van twee DataTable objecten met grotendeels vergelijkbare schema's. Een samenvoeging wordt meestal gebruikt voor een clienttoepassing om de meest recente wijzigingen van een gegevensbron op te nemen in een bestaande DataTable. Hierdoor kan de clienttoepassing worden vernieuwd DataTable met de meest recente gegevens uit de gegevensbron.
Bij de samenvoegbewerking wordt alleen rekening gehouden met de oorspronkelijke tabel en de tabel die moet worden samengevoegd. Onderliggende tabellen worden niet beïnvloed of opgenomen. Als een tabel een of meer onderliggende tabellen bevat, gedefinieerd als onderdeel van een relatie, moet elke onderliggende tabel afzonderlijk worden samengevoegd.
De Merge methode wordt meestal aan het einde van een reeks procedures aangeroepen die betrekking hebben op het valideren van wijzigingen, het afstemmen van fouten, het bijwerken van de gegevensbron met de wijzigingen en tot slot het vernieuwen van de bestaande DataTable.
Bij het uitvoeren van een samenvoegbewerking worden wijzigingen in de bestaande gegevens bewaard voordat de samenvoegbewerking wordt bewaard, tenzij de ontwikkelaar onwaar opgeeft voor de preserveChanges parameter. Als de preserveChanges parameter is ingesteld op true, overschrijven binnenkomende waarden bestaande waarden niet in de huidige rijversie van de bestaande rij. Als de preserveChanges parameter is ingesteld op false, overschrijven binnenkomende waarden de bestaande waarden in de huidige rijversie van de bestaande rij. Meer informatie over rijversies vindt u in Rijstatussen en rijversies.
In een clienttoepassing is het gebruikelijk om één knop te hebben waarop de gebruiker kan klikken om de gewijzigde gegevens te verzamelen en deze te valideren voordat deze wordt teruggestuurd naar een onderdeel in de middelste laag. In dit scenario wordt de GetChanges methode eerst aangeroepen. Deze methode retourneert een tweede DataTable geoptimaliseerd voor het valideren en samenvoegen. Dit tweede DataTable object bevat alleen de DataTable objecten die DataRow zijn gewijzigd, wat resulteert in een subset van het oorspronkelijke DataTableobject. Deze subset is over het algemeen kleiner en daarom wordt deze subset efficiënter doorgegeven aan een onderdeel van de middelste laag. Het onderdeel van de middelste laag werkt vervolgens de oorspronkelijke gegevensbron bij met de wijzigingen via opgeslagen procedures. De middelste laag kan vervolgens een nieuwe DataTable met oorspronkelijke gegevens en de meest recente gegevens uit de gegevensbron (door de oorspronkelijke query opnieuw uit te voeren) terugsturen, of de subset terugsturen met eventuele wijzigingen die zijn aangebracht vanuit de gegevensbron. (Als de gegevensbron bijvoorbeeld automatisch unieke primaire-sleutelwaarden maakt, kunnen deze waarden worden doorgegeven aan de clienttoepassing.) In beide gevallen kan het geretourneerde DataTable bestand worden samengevoegd met de DataTable oorspronkelijke Merge methode van de clienttoepassing.
Wanneer de Merge methode wordt aangeroepen, worden de schema's van de twee DataTable objecten vergeleken, omdat het mogelijk is dat de schema's zijn gewijzigd. In een business-to-business-scenario kunnen bijvoorbeeld nieuwe kolommen zijn toegevoegd aan een XML-schema door een geautomatiseerd proces. Als de bron DataTable schema-elementen (toegevoegde DataColumn objecten) bevat die ontbreken in het doel, kunnen de schema-elementen aan het doel worden toegevoegd door het missingSchemaAction argument in te stellen op MissingSchemaAction.Add. In dat geval bevat de samengevoegde DataTable het toegevoegde schema en de toegevoegde gegevens.
Na het samenvoegen van schema's worden de gegevens samengevoegd.
Wanneer u een nieuwe bron DataTable samenvoegt in het doel, worden alle bronrijen met een DataRowState waarde van Unchanged, Modifiedof Deleted overeenkomen met doelrijen met dezelfde primaire-sleutelwaarden. Bronrijen met een DataRowState waarde van Added worden vergeleken met nieuwe doelrijen met dezelfde primaire-sleutelwaarden als de nieuwe bronrijen.
Zie ook
Van toepassing op
Merge(DataTable, Boolean)
- Bron:
- DataTable.cs
- Bron:
- DataTable.cs
- Bron:
- DataTable.cs
- Bron:
- DataTable.cs
- Bron:
- DataTable.cs
Voeg de opgegeven DataTable samen met de huidige DataTable, waarmee wordt aangegeven of wijzigingen in de huidige DataTablebehouden blijven.
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)
Parameters
- table
- DataTable
De DataTable te samenvoegen met de huidige DataTable.
- preserveChanges
- Boolean
true, om wijzigingen in de huidige DataTablete behouden ; anders false.
Voorbeelden
De volgende consoletoepassing maakt een DataTable met rijen, wijzigt enkele van de gegevens in deze rijen en probeert gegevens uit een andere DataTablerij samen te voegen. In het voorbeeld ziet u het verschillende gedrag voor de 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
Opmerkingen
De methode Samenvoegen wordt gebruikt om twee DataTable objecten met grotendeels vergelijkbare schema's samen te voegen. Een samenvoeging wordt meestal gebruikt voor een clienttoepassing om de meest recente wijzigingen van een gegevensbron op te nemen in een bestaande DataTable. Hierdoor kan de clienttoepassing worden vernieuwd DataTable met de meest recente gegevens uit de gegevensbron.
Bij de samenvoegbewerking wordt alleen rekening gehouden met de oorspronkelijke tabel en de tabel die moet worden samengevoegd. Onderliggende tabellen worden niet beïnvloed of opgenomen. Als een tabel een of meer onderliggende tabellen bevat, gedefinieerd als onderdeel van een relatie, moet elke onderliggende tabel afzonderlijk worden samengevoegd.
De Merge methode wordt meestal aan het einde van een reeks procedures aangeroepen die betrekking hebben op het valideren van wijzigingen, het afstemmen van fouten, het bijwerken van de gegevensbron met de wijzigingen en tot slot het vernieuwen van de bestaande DataTable.
Bij het uitvoeren van een samenvoegbewerking worden wijzigingen in de bestaande gegevens bewaard voordat de samenvoegbewerking wordt bewaard, tenzij de ontwikkelaar onwaar opgeeft voor de preserveChanges parameter. Als de preserveChanges parameter is ingesteld op true, overschrijven binnenkomende waarden bestaande waarden niet in de huidige rijversie van de bestaande rij. Als de preserveChanges parameter is ingesteld op false, overschrijven binnenkomende waarden de bestaande waarden in de huidige rijversie van de bestaande rij. Meer informatie over rijversies vindt u in Rijstatussen en rijversies.
In een clienttoepassing is het gebruikelijk om één knop te hebben waarop de gebruiker kan klikken om de gewijzigde gegevens te verzamelen en deze te valideren voordat deze wordt teruggestuurd naar een onderdeel in de middelste laag. In dit scenario wordt de GetChanges methode eerst aangeroepen. Deze methode retourneert een tweede DataTable geoptimaliseerd voor het valideren en samenvoegen. Dit tweede DataTable object bevat alleen de DataTable objecten die DataRow zijn gewijzigd, wat resulteert in een subset van het oorspronkelijke DataTableobject. Deze subset is over het algemeen kleiner en daarom wordt deze subset efficiënter doorgegeven aan een onderdeel van de middelste laag. Het onderdeel van de middelste laag werkt vervolgens de oorspronkelijke gegevensbron bij met de wijzigingen via opgeslagen procedures. De middelste laag kan vervolgens een nieuwe DataTable met oorspronkelijke gegevens en de meest recente gegevens uit de gegevensbron (door de oorspronkelijke query opnieuw uit te voeren) terugsturen, of de subset terugsturen met eventuele wijzigingen die zijn aangebracht vanuit de gegevensbron. (Als de gegevensbron bijvoorbeeld automatisch unieke primaire-sleutelwaarden maakt, kunnen deze waarden worden doorgegeven aan de clienttoepassing.) In beide gevallen kan het geretourneerde DataTable bestand worden samengevoegd met de DataTable oorspronkelijke Merge methode van de clienttoepassing.
Wanneer u een nieuwe bron DataTable samenvoegt in het doel, worden alle bronrijen met een DataRowState waarde van Unchanged, Modifiedof Deleted overeenkomen met doelrijen met dezelfde primaire-sleutelwaarden. Bronrijen met een DataRowState waarde van Added worden vergeleken met nieuwe doelrijen met dezelfde primaire-sleutelwaarden als de nieuwe bronrijen.
Zie ook
Van toepassing op
Merge(DataTable)
- Bron:
- DataTable.cs
- Bron:
- DataTable.cs
- Bron:
- DataTable.cs
- Bron:
- DataTable.cs
- Bron:
- 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)
Parameters
Voorbeelden
De volgende consoletoepassing maakt een eenvoudige DataTable en voegt gegevens toe aan de tabel. In het voorbeeld wordt vervolgens een kopie van de tabel gemaakt, waarbij rijen aan de kopie worden toegevoegd. Ten slotte roept het voorbeeld de Merge methode aan om de gegevens in de tweede tabel samen te voegen met de gegevens in de eerste tabel.
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
Opmerkingen
De methode Samenvoegen wordt gebruikt om twee DataTable objecten met grotendeels vergelijkbare schema's samen te voegen. Een samenvoeging wordt meestal gebruikt voor een clienttoepassing om de meest recente wijzigingen van een gegevensbron op te nemen in een bestaande DataTable. Hierdoor kan de clienttoepassing worden vernieuwd DataTable met de meest recente gegevens uit de gegevensbron.
Bij de samenvoegbewerking wordt alleen rekening gehouden met de oorspronkelijke tabel en de tabel die moet worden samengevoegd. Onderliggende tabellen worden niet beïnvloed of opgenomen. Als een tabel een of meer onderliggende tabellen bevat, gedefinieerd als onderdeel van een relatie, moet elke onderliggende tabel afzonderlijk worden samengevoegd.
De Merge methode wordt meestal aan het einde van een reeks procedures aangeroepen die betrekking hebben op het valideren van wijzigingen, het afstemmen van fouten, het bijwerken van de gegevensbron met de wijzigingen en tot slot het vernieuwen van de bestaande DataTable.
Wanneer u een samenvoegbewerking uitvoert, blijven wijzigingen die zijn aangebracht in de bestaande gegevens standaard behouden tijdens de samenvoegbewerking. Ontwikkelaars kunnen dit gedrag wijzigen door een van de andere twee overbelastingen voor deze methode aan te roepen en een valse waarde voor de preserveChanges parameter op te geven.
In een clienttoepassing is het gebruikelijk om één knop te hebben waarop de gebruiker kan klikken om de gewijzigde gegevens te verzamelen en deze te valideren voordat deze wordt teruggestuurd naar een onderdeel in de middelste laag. In dit scenario wordt de GetChanges methode eerst aangeroepen. Deze methode retourneert een tweede DataTable geoptimaliseerd voor het valideren en samenvoegen. Dit tweede DataTable object bevat alleen de DataRow objecten die zijn gewijzigd, wat resulteert in een subset van het oorspronkelijke DataTableobject. Deze subset is over het algemeen kleiner en dus efficiënter teruggegeven aan een middelste laagonderdeel. Het onderdeel van de middelste laag werkt vervolgens de oorspronkelijke gegevensbron bij met de wijzigingen via opgeslagen procedures. De middelste laag kan vervolgens een nieuwe DataTable met oorspronkelijke gegevens en de meest recente gegevens uit de gegevensbron (door de oorspronkelijke query opnieuw uit te voeren) terugsturen, of de subset terugsturen met eventuele wijzigingen die zijn aangebracht vanuit de gegevensbron. (Als de gegevensbron bijvoorbeeld automatisch unieke primaire-sleutelwaarden maakt, kunnen deze waarden worden doorgegeven aan de clienttoepassing.) In beide gevallen kan het geretourneerde DataTable bestand worden samengevoegd met de DataTable oorspronkelijke Merge methode van de clienttoepassing.
Wanneer u een nieuwe bron DataTable samenvoegt in het doel, worden alle bronrijen met een DataRowState waarde van Unchanged, Modifiedof Deleted, vergeleken met doelrijen met dezelfde primaire-sleutelwaarden. Bronrijen met een DataRowState waarde van Added worden vergeleken met nieuwe doelrijen met dezelfde primaire-sleutelwaarden als de nieuwe bronrijen.