DataTable.Merge Methode
Definition
Wichtig
Einige Informationen beziehen sich auf Vorabversionen, die vor dem Release ggf. grundlegend überarbeitet werden. Microsoft übernimmt hinsichtlich der hier bereitgestellten Informationen keine Gewährleistungen, seien sie ausdrücklich oder konkludent.
Überlädt
Merge(DataTable, Boolean, MissingSchemaAction) |
Führen Sie die angegebene DataTable mit der aktuellen |
Merge(DataTable, Boolean) |
Führen Sie die angegebene DataTable mit der aktuellen |
Merge(DataTable) |
Führen Sie die angegebene DataTable mit der aktuellen DataTable zusammen. |
Beispiele
Die folgende Konsolenanwendung veranschaulicht das Verhalten des missingSchemaAction
Parameters der Merge -Methode. In diesem Beispiel werden zwei Versionen derselben Tabelle erstellt, wobei das Schema für die zweite Version geändert wird. Der Code versucht dann, die zweite Tabelle in der ersten zusammenzuführen.
Hinweis
In diesem Beispiel wird gezeigt, wie Sie eine der überladenen Versionen von Merge verwenden. Weitere Beispiele, die möglicherweise verfügbar sind, finden Sie in den einzelnen Überladungsthemen.
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
Hinweise
Die Merge
-Methode wird verwendet, um zwei DataTable Objekte zusammenzuführen, die weitgehend ähnliche Schemas aufweisen. Eine Zusammenführung wird in der Regel für eine Clientanwendung verwendet, um die neuesten Änderungen aus einer Datenquelle in eine vorhandene DataTablezu integrieren. Dadurch kann die Clientanwendung eine Aktualisierung DataTable mit den neuesten Daten aus der Datenquelle erhalten.
Der Mergevorgang berücksichtigt nur die ursprüngliche Tabelle und die tabelle, die zusammengeführt werden soll. Untergeordnete Tabellen sind nicht betroffen oder enthalten. Wenn eine Tabelle eine oder mehrere untergeordnete Tabellen aufweist, die als Teil einer Beziehung definiert sind, muss jede untergeordnete Tabelle einzeln zusammengeführt werden.
Merge(DataTable, Boolean, MissingSchemaAction)
- Quelle:
- DataTable.cs
- Quelle:
- DataTable.cs
- Quelle:
- DataTable.cs
Führen Sie die angegebene DataTable mit der aktuellen DataTable
zusammen, und geben Sie an, ob die Änderungen in der aktuellen DataTable
beibehalten werden sollen und wie das fehlende Schema behandelt werden soll.
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)
Parameter
- preserveChanges
- Boolean
true
, um an der aktuellen DataTable vorgenommene Änderungen beizubehalten, andernfalls false
.
- missingSchemaAction
- MissingSchemaAction
Einer der MissingSchemaAction-Werte.
Beispiele
Die folgende Konsolenanwendung veranschaulicht das Verhalten des missingSchemaAction
Parameters der Merge -Methode. In diesem Beispiel werden zwei Versionen derselben Tabelle erstellt, wobei das Schema für die zweite Version geändert wird. Der Code versucht dann, die zweite Tabelle in der ersten zusammenzuführen.
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
Hinweise
Die Merge
-Methode wird verwendet, um zwei DataTable Objekte zusammenzuführen, die weitgehend ähnliche Schemas aufweisen. Ein Merge wird in der Regel für eine Clientanwendung verwendet, um die neuesten Änderungen aus einer Datenquelle in eine vorhandene DataTablezu integrieren. Dadurch kann die Clientanwendung mit den neuesten Daten aus der Datenquelle aktualisiert DataTable werden.
Der Mergevorgang berücksichtigt nur die ursprüngliche Tabelle und die tabelle, die zusammengeführt werden soll. Untergeordnete Tabellen sind nicht betroffen oder enthalten. Wenn eine Tabelle über eine oder mehrere untergeordnete Tabellen verfügt, die als Teil einer Beziehung definiert sind, muss jede untergeordnete Tabelle einzeln zusammengeführt werden.
Die Merge
-Methode wird in der Regel am Ende einer Reihe von Prozeduren aufgerufen, die das Überprüfen von Änderungen, das Abgleichen von Fehlern, das Aktualisieren der Datenquelle mit den Änderungen und schließlich das Aktualisieren der vorhandenen DataTableumfassen.
Beim Ausführen einer Zusammenführung werden Änderungen, die vor dem Zusammenführen an den vorhandenen Daten vorgenommen wurden, während des Mergevorgangs beibehalten, es sei denn, der Entwickler gibt false für den preserveChanges
Parameter an. Wenn der preserveChanges
Parameter auf true
festgelegt ist, überschreiben eingehende Werte keine vorhandenen Werte in der Aktuellen Zeilenversion der vorhandenen Zeile. Wenn der preserveChanges
Parameter auf false
festgelegt ist, überschreiben eingehende Werte die vorhandenen Werte in der Aktuellen Zeilenversion der vorhandenen Zeile. Weitere Informationen finden Sie unter Zeilenzustände und Zeilenversionen.
In einer Clientanwendung ist es üblich, über eine einzelne Schaltfläche zu verfügen, auf die der Benutzer klicken kann, um die geänderten Daten zu sammeln und zu überprüfen, bevor sie an eine Komponente der mittleren Ebene zurücksenden. In diesem Szenario wird zuerst die GetChanges -Methode aufgerufen. Diese Methode gibt eine Sekunde DataTable zurück, die für die Validierung und Zusammenführung optimiert ist. Dieses zweite DataTable Objekt enthält nur die DataTable - und DataRow -Objekte, die geändert wurden, was zu einer Teilmenge des ursprünglichen DataTable-Objekts führt. Diese Teilmenge ist im Allgemeinen kleiner, sodass diese Teilmenge effizienter an eine Komponente der mittleren Ebene zurückgegeben wird. Die Komponente der mittleren Ebene aktualisiert dann die ursprüngliche Datenquelle mit den Änderungen über gespeicherte Prozeduren. Die mittlere Ebene kann dann entweder eine neue DataTable zurücksenden, die originale Daten und die neuesten Daten aus der Datenquelle enthält (indem die ursprüngliche Abfrage erneut ausgeführt wird), oder sie kann die Teilmenge mit allen Änderungen zurücksenden, die von der Datenquelle an sie vorgenommen wurden. (Wenn die Datenquelle beispielsweise automatisch eindeutige Primärschlüsselwerte erstellt, können diese Werte zurück an die Clientanwendung weitergegeben werden.) In beiden Fällen kann das zurückgegebene DataTable mit der -Methode wieder in das Original DataTable der Merge Clientanwendung zusammengeführt werden.
Wenn die Merge -Methode aufgerufen wird, werden die Schemas der beiden DataTable -Objekte verglichen, da die Schemas möglicherweise geändert wurden. In einem Business-to-Business-Szenario wurden z. B. möglicherweise durch einen automatisierten Prozess neue Spalten zu einem XML-Schema hinzugefügt. Wenn die Quelle DataTable Schemaelemente (hinzugefügte DataColumn Objekte) enthält, die im Ziel fehlen, können die Schemaelemente dem Ziel hinzugefügt werden, indem Sie das missingSchemaAction
Argument auf MissingSchemaAction.Add
festlegen. In diesem Fall enthält das zusammengeführte DataTable das hinzugefügte Schema und die hinzugefügten Daten.
Nach dem Zusammenführen von Schemas werden die Daten zusammengeführt.
Beim Zusammenführen einer neuen Quelle DataTable in das Ziel werden alle Quellzeilen mit dem DataRowState Wert Unchanged
, Modified
oder Deleted
mit Zielzeilen mit denselben Primärschlüsselwerten abgeglichen. Quellzeilen mit dem DataRowState Wert von Added
werden mit neuen Zielzeilen mit denselben Primärschlüsselwerten wie die neuen Quellzeilen abgeglichen.
Weitere Informationen
Gilt für:
Merge(DataTable, Boolean)
- Quelle:
- DataTable.cs
- Quelle:
- DataTable.cs
- Quelle:
- DataTable.cs
Führen Sie die angegebene DataTable mit der aktuellen DataTable
zusammen, und geben Sie an, ob die Änderungen in der aktuellen DataTable
beibehalten werden sollen.
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)
Parameter
- table
- DataTable
Die DataTable
, die mit der aktuellen DataTable
zusammengeführt werden soll.
- preserveChanges
- Boolean
true
, um an der aktuellen DataTable
vorgenommene Änderungen beizubehalten, andernfalls false
.
Beispiele
Die folgende Konsolenanwendung erstellt eine DataTable , die Zeilen enthält, ändert einige der Daten in diesen Zeilen und versucht, Daten aus einem anderen DataTablezusammenzuführen. Im Beispiel werden die verschiedenen Verhaltensweisen für den preserveChanges
Parameter veranschaulicht.
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
Hinweise
Die Merge-Methode wird verwendet, um zwei DataTable Objekte zusammenzuführen, die weitgehend ähnliche Schemas aufweisen. Ein Merge wird in der Regel für eine Clientanwendung verwendet, um die neuesten Änderungen aus einer Datenquelle in eine vorhandene DataTablezu integrieren. Dadurch kann die Clientanwendung mit den neuesten Daten aus der Datenquelle aktualisiert DataTable werden.
Der Mergevorgang berücksichtigt nur die ursprüngliche Tabelle und die tabelle, die zusammengeführt werden soll. Untergeordnete Tabellen sind nicht betroffen oder enthalten. Wenn eine Tabelle über eine oder mehrere untergeordnete Tabellen verfügt, die als Teil einer Beziehung definiert sind, muss jede untergeordnete Tabelle einzeln zusammengeführt werden.
Die Merge
-Methode wird in der Regel am Ende einer Reihe von Prozeduren aufgerufen, die das Überprüfen von Änderungen, das Abgleichen von Fehlern, das Aktualisieren der Datenquelle mit den Änderungen und schließlich das Aktualisieren der vorhandenen DataTableumfassen.
Beim Ausführen einer Zusammenführung werden Änderungen, die vor dem Zusammenführen an den vorhandenen Daten vorgenommen wurden, während des Mergevorgangs beibehalten, es sei denn, der Entwickler gibt false für den preserveChanges
Parameter an. Wenn der preserveChanges
Parameter auf true
festgelegt ist, überschreiben eingehende Werte keine vorhandenen Werte in der Aktuellen Zeilenversion der vorhandenen Zeile. Wenn der preserveChanges
Parameter auf false
festgelegt ist, überschreiben eingehende Werte die vorhandenen Werte in der Aktuellen Zeilenversion der vorhandenen Zeile. Weitere Informationen finden Sie unter Zeilenzustände und Zeilenversionen.
In einer Clientanwendung ist es üblich, über eine einzelne Schaltfläche zu verfügen, auf die der Benutzer klicken kann, um die geänderten Daten zu sammeln und zu überprüfen, bevor sie an eine Komponente der mittleren Ebene zurücksenden. In diesem Szenario wird zuerst die GetChanges -Methode aufgerufen. Diese Methode gibt eine Sekunde DataTable zurück, die für die Validierung und Zusammenführung optimiert ist. Dieses zweite DataTable Objekt enthält nur die DataTable - und DataRow -Objekte, die geändert wurden, was zu einer Teilmenge des ursprünglichen DataTable-Objekts führt. Diese Teilmenge ist im Allgemeinen kleiner, sodass diese Teilmenge effizienter an eine Komponente der mittleren Ebene zurückgegeben wird. Die Komponente der mittleren Ebene aktualisiert dann die ursprüngliche Datenquelle mit den Änderungen über gespeicherte Prozeduren. Die mittlere Ebene kann dann entweder eine neue DataTable zurücksenden, die originale Daten und die neuesten Daten aus der Datenquelle enthält (indem die ursprüngliche Abfrage erneut ausgeführt wird), oder sie kann die Teilmenge mit allen Änderungen zurücksenden, die von der Datenquelle an sie vorgenommen wurden. (Wenn die Datenquelle beispielsweise automatisch eindeutige Primärschlüsselwerte erstellt, können diese Werte zurück an die Clientanwendung weitergegeben werden.) In beiden Fällen kann das zurückgegebene DataTable mit der -Methode wieder in das Original DataTable der Merge Clientanwendung zusammengeführt werden.
Beim Zusammenführen einer neuen Quelle DataTable in das Ziel werden alle Quellzeilen mit dem DataRowState Wert Unchanged
, Modified
oder Deleted
mit Zielzeilen mit denselben Primärschlüsselwerten abgeglichen. Quellzeilen mit dem DataRowState Wert von Added
werden mit neuen Zielzeilen mit denselben Primärschlüsselwerten wie die neuen Quellzeilen abgeglichen.
Weitere Informationen
Gilt für:
Merge(DataTable)
- Quelle:
- DataTable.cs
- Quelle:
- DataTable.cs
- Quelle:
- 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)
Parameter
Beispiele
Die folgende Konsolenanwendung erstellt eine einfache DataTable und fügt der Tabelle Daten hinzu. Im Beispiel wird dann eine Kopie der Tabelle erstellt und der Kopie Zeilen hinzugefügt. Schließlich ruft das Beispiel die Merge -Methode auf, um die Daten in der zweiten Tabelle mit den Daten in der ersten Tabelle zusammenzuführen.
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
Hinweise
Die Merge-Methode wird verwendet, um zwei DataTable Objekte zusammenzuführen, die weitgehend ähnliche Schemas aufweisen. Ein Merge wird in der Regel für eine Clientanwendung verwendet, um die neuesten Änderungen aus einer Datenquelle in eine vorhandene DataTablezu integrieren. Dadurch kann die Clientanwendung mit den neuesten Daten aus der Datenquelle aktualisiert DataTable werden.
Der Mergevorgang berücksichtigt nur die ursprüngliche Tabelle und die tabelle, die zusammengeführt werden soll. Untergeordnete Tabellen sind nicht betroffen oder enthalten. Wenn eine Tabelle über eine oder mehrere untergeordnete Tabellen verfügt, die als Teil einer Beziehung definiert sind, muss jede untergeordnete Tabelle einzeln zusammengeführt werden.
Die Merge
-Methode wird in der Regel am Ende einer Reihe von Prozeduren aufgerufen, die das Überprüfen von Änderungen, das Abgleichen von Fehlern, das Aktualisieren der Datenquelle mit den Änderungen und schließlich das Aktualisieren der vorhandenen DataTableumfassen.
Beim Ausführen einer Zusammenführung werden Änderungen, die vor dem Zusammenführen an den vorhandenen Daten vorgenommen wurden, während des Mergevorgangs standardmäßig beibehalten. Entwickler können dieses Verhalten ändern, indem sie eine der beiden anderen Überladungen für diese Methode aufrufen und einen false-Wert für den preserveChanges
Parameter angeben.
In einer Clientanwendung ist es üblich, über eine einzelne Schaltfläche zu verfügen, auf die der Benutzer klicken kann, um die geänderten Daten zu sammeln und zu überprüfen, bevor sie an eine Komponente der mittleren Ebene zurücksenden. In diesem Szenario wird zuerst die GetChanges -Methode aufgerufen. Diese Methode gibt eine Sekunde DataTable zurück, die für die Validierung und Zusammenführung optimiert ist. Dieses zweite DataTable Objekt enthält nur die -Objekte, die DataRow geändert wurden, was zu einer Teilmenge des ursprünglichen DataTable-Objekts führt. Diese Teilmenge ist im Allgemeinen kleiner und wird daher effizienter an eine Komponente der mittleren Ebene zurückgegeben. Die Komponente der mittleren Ebene aktualisiert dann die ursprüngliche Datenquelle mit den Änderungen über gespeicherte Prozeduren. Die mittlere Ebene kann dann entweder eine neue DataTable zurücksenden, die originale Daten und die neuesten Daten aus der Datenquelle enthält (indem die ursprüngliche Abfrage erneut ausgeführt wird), oder sie kann die Teilmenge mit allen Änderungen zurücksenden, die von der Datenquelle an sie vorgenommen wurden. (Wenn die Datenquelle beispielsweise automatisch eindeutige Primärschlüsselwerte erstellt, können diese Werte zurück an die Clientanwendung weitergegeben werden.) In beiden Fällen kann das zurückgegebene DataTable mit der -Methode wieder in das Original DataTable der Merge Clientanwendung zusammengeführt werden.
Beim Zusammenführen einer neuen Quelle DataTable mit dem Ziel werden alle Quellzeilen mit dem DataRowState Wert Unchanged
, Modified
oder Deleted
, mit Zielzeilen mit denselben Primärschlüsselwerten abgeglichen. Quellzeilen mit dem DataRowState Wert von Added
werden mit neuen Zielzeilen mit den gleichen Primärschlüsselwerten wie die neuen Quellzeilen abgeglichen.