DataTable.Merge Metodo

Definizione

Unire la classe DataTable specificata alla classe DataTable corrente.

Overload

Merge(DataTable, Boolean, MissingSchemaAction)

Unire la classe DataTable specificata alla classe DataTable corrente, indicando se conservare le modifiche e come gestire lo schema mancante nella classe DataTable corrente.

Merge(DataTable, Boolean)

Unire la classe DataTable specificata alla classe DataTable corrente, indicando se conservare le modifiche nella classe DataTable corrente.

Merge(DataTable)

Unire la classe DataTable specificata alla classe DataTable corrente.

Esempio

L'applicazione console seguente illustra il comportamento del missingSchemaAction parametro del Merge metodo . In questo esempio vengono create due versioni della stessa tabella, modificando lo schema per la seconda versione. Il codice tenta quindi di unire la seconda tabella nel primo.

Nota

In questo esempio viene illustrato come usare una delle versioni di overload di Merge. Per altri esempi che potrebbero essere disponibili, vedere i singoli argomenti di overload.

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

Commenti

Il Merge metodo viene usato per unire due DataTable oggetti con schemi in gran parte simili. Un'unione viene in genere usata in un'applicazione client per incorporare le modifiche più recenti da un'origine dati in un oggetto esistente DataTable. Ciò consente all'applicazione client di aggiornare con DataTable i dati più recenti dall'origine dati.

L'operazione di unione tiene conto solo della tabella originale e della tabella da unire. Le tabelle figlio non sono interessate o incluse. Se una tabella include una o più tabelle figlio, definite come parte di una relazione, ogni tabella figlio deve essere unita singolarmente.

Merge(DataTable, Boolean, MissingSchemaAction)

Origine:
DataTable.cs
Origine:
DataTable.cs
Origine:
DataTable.cs

Unire la classe DataTable specificata alla classe DataTable corrente, indicando se conservare le modifiche e come gestire lo schema mancante nella classe DataTable corrente.

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)

Parametri

table
DataTable

Classe DataTable da unire alla classe DataTable corrente.

preserveChanges
Boolean

true per conservare le modifiche apportate all'oggetto DataTable corrente; in caso contrario, false.

missingSchemaAction
MissingSchemaAction

Uno dei valori di MissingSchemaAction.

Esempio

L'applicazione console seguente illustra il comportamento del missingSchemaAction parametro del Merge metodo . In questo esempio vengono create due versioni della stessa tabella, modificando lo schema per la seconda versione. Il codice tenta quindi di unire la seconda tabella nel primo.

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

Commenti

Il Merge metodo viene usato per unire due DataTable oggetti con schemi in gran parte simili. Un'unione viene in genere usata in un'applicazione client per incorporare le modifiche più recenti da un'origine dati in un oggetto esistente DataTable. Ciò consente all'applicazione client di aggiornare con DataTable i dati più recenti dall'origine dati.

L'operazione di unione tiene conto solo della tabella originale e della tabella da unire. Le tabelle figlio non sono interessate o incluse. Se una tabella include una o più tabelle figlio, definite come parte di una relazione, ogni tabella figlio deve essere unita singolarmente.

Il Merge metodo viene in genere chiamato alla fine di una serie di procedure che comportano la convalida delle modifiche, la riconciliazione degli errori, l'aggiornamento dell'origine dati con le modifiche e infine l'aggiornamento dell'oggetto esistente DataTable.

Quando si esegue un'unione, le modifiche apportate ai dati esistenti prima dell'unione vengono mantenute durante l'operazione di merge, a meno che lo sviluppatore non specifichi false per il preserveChanges parametro . Se il parametro è impostato su true, i preserveChanges valori in ingresso non sovrascrivono i valori esistenti nella versione corrente della riga esistente. Se il parametro è impostato su false, i preserveChanges valori in ingresso sovrascrivono i valori esistenti nella versione corrente della riga esistente. Per altre informazioni sulle versioni delle righe, vedere Stati di riga e versioni di riga.

In un'applicazione client è in genere necessario un singolo pulsante su cui l'utente può fare clic per raccogliere i dati modificati e convalidarlo prima di inviarlo a un componente di livello intermedio. In questo scenario, il GetChanges metodo viene richiamato per primo. Questo metodo restituisce un secondo DataTable ottimizzato per la convalida e l'unione. Questo secondo DataTable oggetto contiene solo gli DataTable oggetti e DataRow modificati, con conseguente sottoinsieme dell'oggetto originale DataTable. Questo subset è in genere più piccolo e quindi questo subset viene passato in modo più efficiente a un componente di livello intermedio. Il componente di livello intermedio aggiorna quindi l'origine dati originale con le modifiche tramite stored procedure. Il livello intermedio può quindi restituire un nuovo DataTable oggetto che include i dati originali e i dati più recenti dall'origine dati (eseguendo di nuovo la query originale) oppure può restituire il subset con tutte le modifiche apportate dall'origine dati. Ad esempio, se l'origine dati crea automaticamente valori di chiave primaria univoci, questi valori possono essere propagati all'applicazione client. In entrambi i casi, l'oggetto restituito DataTable può essere unito nuovamente all'originale DataTable dell'applicazione client con il Merge metodo .

Quando viene chiamato il Merge metodo , gli schemi dei due DataTable oggetti vengono confrontati, perché è possibile che gli schemi siano stati modificati. Ad esempio, in uno scenario business-to-business, è possibile che nuove colonne siano state aggiunte a uno schema XML da un processo automatizzato. Se l'origine DataTable contiene elementi dello schema (oggetti aggiunti DataColumn ) mancanti nella destinazione, gli elementi dello schema possono essere aggiunti alla destinazione impostando l'argomento missingSchemaAction su MissingSchemaAction.Add. In tal caso, l'oggetto unito DataTable contiene lo schema e i dati aggiunti.

Dopo l'unione degli schemi, i dati vengono uniti.

Quando si uniscono una nuova origine DataTable nella destinazione, tutte le righe di Unchangedorigine con un DataRowState valore , Modifiedo Deleted vengono confrontate con le righe di destinazione con gli stessi valori di chiave primaria. Le righe di origine con un DataRowState valore di vengono confrontate con le nuove righe di Added destinazione con gli stessi valori di chiave primaria delle nuove righe di origine.

Vedi anche

Si applica a

Merge(DataTable, Boolean)

Origine:
DataTable.cs
Origine:
DataTable.cs
Origine:
DataTable.cs

Unire la classe DataTable specificata alla classe DataTable corrente, indicando se conservare le modifiche nella classe DataTable corrente.

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)

Parametri

table
DataTable

Classe DataTable da unire alla classe DataTable corrente.

preserveChanges
Boolean

true per conservare le modifiche apportate all'oggetto DataTable corrente; in caso contrario, false.

Esempio

L'applicazione console seguente crea un DataTable oggetto contenente righe, modifica alcuni dei dati in tali righe e tenta di unire i dati da un oggetto diverso DataTable. Nell'esempio vengono illustrati i diversi comportamenti per il preserveChanges parametro .


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

Commenti

Il metodo Merge viene utilizzato per unire due DataTable oggetti con schemi in gran parte simili. Un'unione viene in genere usata in un'applicazione client per incorporare le modifiche più recenti da un'origine dati in un oggetto esistente DataTable. Ciò consente all'applicazione client di aggiornare con DataTable i dati più recenti dall'origine dati.

L'operazione di unione tiene conto solo della tabella originale e della tabella da unire. Le tabelle figlio non sono interessate o incluse. Se una tabella include una o più tabelle figlio, definite come parte di una relazione, ogni tabella figlio deve essere unita singolarmente.

Il Merge metodo viene in genere chiamato alla fine di una serie di procedure che comportano la convalida delle modifiche, la riconciliazione degli errori, l'aggiornamento dell'origine dati con le modifiche e infine l'aggiornamento dell'oggetto esistente DataTable.

Quando si esegue un'unione, le modifiche apportate ai dati esistenti prima dell'unione vengono mantenute durante l'operazione di merge, a meno che lo sviluppatore non specifichi false per il preserveChanges parametro . Se il parametro è impostato su true, i preserveChanges valori in ingresso non sovrascrivono i valori esistenti nella versione corrente della riga esistente. Se il parametro è impostato su false, i preserveChanges valori in ingresso sovrascrivono i valori esistenti nella versione corrente della riga esistente. Per altre informazioni sulle versioni delle righe, vedere Stati di riga e versioni di riga.

In un'applicazione client è in genere necessario un singolo pulsante su cui l'utente può fare clic per raccogliere i dati modificati e convalidarlo prima di inviarlo a un componente di livello intermedio. In questo scenario, il GetChanges metodo viene richiamato per primo. Questo metodo restituisce un secondo DataTable ottimizzato per la convalida e l'unione. Questo secondo DataTable oggetto contiene solo gli DataTable oggetti e DataRow modificati, con conseguente sottoinsieme dell'oggetto originale DataTable. Questo subset è in genere più piccolo e quindi questo subset viene passato in modo più efficiente a un componente di livello intermedio. Il componente di livello intermedio aggiorna quindi l'origine dati originale con le modifiche tramite stored procedure. Il livello intermedio può quindi restituire un nuovo DataTable oggetto che include i dati originali e i dati più recenti dall'origine dati (eseguendo di nuovo la query originale) oppure può restituire il subset con tutte le modifiche apportate dall'origine dati. Ad esempio, se l'origine dati crea automaticamente valori di chiave primaria univoci, questi valori possono essere propagati all'applicazione client. In entrambi i casi, l'oggetto restituito DataTable può essere unito nuovamente all'originale DataTable dell'applicazione client con il Merge metodo .

Quando si uniscono una nuova origine DataTable nella destinazione, tutte le righe di Unchangedorigine con un DataRowState valore , Modifiedo Deleted vengono confrontate con le righe di destinazione con gli stessi valori di chiave primaria. Le righe di origine con un DataRowState valore di vengono confrontate con le nuove righe di Added destinazione con gli stessi valori di chiave primaria delle nuove righe di origine.

Vedi anche

Si applica a

Merge(DataTable)

Origine:
DataTable.cs
Origine:
DataTable.cs
Origine:
DataTable.cs

Unire la classe DataTable specificata alla classe DataTable corrente.

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)

Parametri

table
DataTable

Classe DataTable da unire alla classe DataTable corrente.

Esempio

L'applicazione console seguente crea un semplice DataTable oggetto e aggiunge dati alla tabella. Nell'esempio viene quindi creata una copia della tabella, aggiungendo righe alla copia. Infine, nell'esempio viene chiamato il Merge metodo per unire i dati nella seconda tabella con i dati nella prima tabella.

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

Commenti

Il metodo Merge viene utilizzato per unire due DataTable oggetti con schemi in gran parte simili. Un'unione viene in genere usata in un'applicazione client per incorporare le modifiche più recenti da un'origine dati in un oggetto esistente DataTable. Ciò consente all'applicazione client di aggiornare con DataTable i dati più recenti dall'origine dati.

L'operazione di unione tiene conto solo della tabella originale e della tabella da unire. Le tabelle figlio non sono interessate o incluse. Se una tabella include una o più tabelle figlio, definite come parte di una relazione, ogni tabella figlio deve essere unita singolarmente.

Il Merge metodo viene in genere chiamato alla fine di una serie di procedure che comportano la convalida delle modifiche, la riconciliazione degli errori, l'aggiornamento dell'origine dati con le modifiche e infine l'aggiornamento dell'oggetto esistente DataTable.

Quando si esegue un'unione, le modifiche apportate ai dati esistenti prima dell'unione vengono mantenute per impostazione predefinita durante l'operazione di unione. Gli sviluppatori possono modificare questo comportamento chiamando uno degli altri due overload per questo metodo e specificando un valore false per il preserveChanges parametro .

In un'applicazione client è in genere necessario un singolo pulsante su cui l'utente può fare clic per raccogliere i dati modificati e convalidarlo prima di inviarlo a un componente di livello intermedio. In questo scenario, il GetChanges metodo viene richiamato per primo. Questo metodo restituisce un secondo DataTable ottimizzato per la convalida e l'unione. Questo secondo DataTable oggetto contiene solo gli DataRow oggetti modificati, con conseguente sottoinsieme dell'oggetto originale DataTable. Questo subset è in genere più piccolo e quindi è più efficiente passato a un componente di livello intermedio. Il componente di livello intermedio aggiorna quindi l'origine dati originale con le modifiche tramite stored procedure. Il livello intermedio può quindi restituire un nuovo DataTable oggetto che include i dati originali e i dati più recenti dall'origine dati (eseguendo di nuovo la query originale) oppure può restituire il subset con tutte le modifiche apportate dall'origine dati. Ad esempio, se l'origine dati crea automaticamente valori di chiave primaria univoci, questi valori possono essere propagati all'applicazione client. In entrambi i casi, l'oggetto restituito DataTable può essere unito nuovamente all'originale DataTable dell'applicazione client con il Merge metodo .

Quando si uniscono una nuova origine DataTable nella destinazione, tutte le righe di Unchangedorigine con un DataRowState valore , Modifiedo Deletedcorrispondono alle righe di destinazione con gli stessi valori di chiave primaria. Le righe di origine con un DataRowState valore di vengono confrontate con le nuove righe di Added destinazione con gli stessi valori di chiave primaria delle nuove righe di origine.

Vedi anche

Si applica a