DataTable.Merge Método

Definición

Combina el objeto DataTable especificado con el objeto DataTable actual.

Sobrecargas

Merge(DataTable, Boolean, MissingSchemaAction)

Combina el objeto DataTable especificado con el objeto DataTable actual, indicando si se van a conservar los cambios y cómo se va a controlar el esquema que falta en el objeto DataTable actual.

Merge(DataTable, Boolean)

Combina el objeto DataTable especificado con el objeto DataTable actual, indicando si se deben conservar los cambios en el objeto DataTable actual.

Merge(DataTable)

Combina el objeto DataTable especificado con el objeto DataTable actual.

Ejemplos

La siguiente aplicación de consola muestra el comportamiento del missingSchemaAction parámetro del Merge método . En este ejemplo se crean dos versiones de la misma tabla, modificando el esquema de la segunda versión. A continuación, el código intenta combinar la segunda tabla en la primera.

Nota

En este ejemplo se muestra cómo usar una de las versiones sobrecargadas de Merge. Para ver otros ejemplos que podrían estar disponibles, consulte los temas de sobrecarga individuales.

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

Comentarios

El Merge método se usa para combinar dos DataTable objetos que tienen esquemas muy similares. Normalmente, una combinación se usa en una aplicación cliente para incorporar los cambios más recientes de un origen de datos en un existente DataTable. Esto permite que la aplicación cliente tenga una actualización DataTable con los datos más recientes del origen de datos.

La operación de combinación solo tiene en cuenta la tabla original y la tabla que se va a combinar. Las tablas secundarias no se ven afectadas ni se incluyen. Si una tabla tiene una o varias tablas secundarias, definidas como parte de una relación, cada tabla secundaria debe combinarse individualmente.

Merge(DataTable, Boolean, MissingSchemaAction)

Combina el objeto DataTable especificado con el objeto DataTable actual, indicando si se van a conservar los cambios y cómo se va a controlar el esquema que falta en el objeto DataTable actual.

public:
 void Merge(System::Data::DataTable ^ table, bool preserveChanges, System::Data::MissingSchemaAction missingSchemaAction);
public void Merge (System.Data.DataTable table, bool preserveChanges, System.Data.MissingSchemaAction missingSchemaAction);
member this.Merge : System.Data.DataTable * bool * System.Data.MissingSchemaAction -> unit
Public Sub Merge (table As DataTable, preserveChanges As Boolean, missingSchemaAction As MissingSchemaAction)

Parámetros

table
DataTable

Objeto DataTable que se va a combinar con el objeto DataTable actual.

preserveChanges
Boolean

true para conservar los cambios realizados en el objeto DataTable actual; de lo contrario, false.

missingSchemaAction
MissingSchemaAction

Uno de los valores de MissingSchemaAction.

Ejemplos

La siguiente aplicación de consola muestra el comportamiento del missingSchemaAction parámetro del Merge método . En este ejemplo se crean dos versiones de la misma tabla, modificando el esquema de la segunda versión. A continuación, el código intenta combinar la segunda tabla en la primera.

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

Comentarios

El Merge método se usa para combinar dos DataTable objetos que tienen esquemas muy similares. Normalmente, una combinación se usa en una aplicación cliente para incorporar los cambios más recientes de un origen de datos en un existente DataTable. Esto permite que la aplicación cliente tenga una actualización DataTable con los datos más recientes del origen de datos.

La operación de combinación solo tiene en cuenta la tabla original y la tabla que se va a combinar. Las tablas secundarias no se ven afectadas ni se incluyen. Si una tabla tiene una o varias tablas secundarias, definidas como parte de una relación, cada tabla secundaria debe combinarse individualmente.

Normalmente Merge , se llama al método al final de una serie de procedimientos que implican la validación de cambios, la conciliación de errores, la actualización del origen de datos con los cambios y, por último, la actualización del existente DataTable.

Al realizar una combinación, los cambios realizados en los datos existentes antes de conservar la combinación durante la operación de combinación a menos que el desarrollador especifique false para el preserveChanges parámetro . Si el preserveChanges parámetro se establece trueen , los valores entrantes no sobrescriben los valores existentes en la versión de fila actual de la fila existente. Si el preserveChanges parámetro se establece falseen , los valores entrantes sobrescriben los valores existentes en la versión de fila actual de la fila existente. Para obtener más información sobre las versiones de fila, vea Estados de fila y Versiones de fila.

En una aplicación cliente, es habitual tener un solo botón en el que el usuario pueda hacer clic que recopile los datos modificados y lo valide antes de volver a enviarlo a un componente de nivel intermedio. En este escenario, primero se invoca el GetChanges método . Ese método devuelve un segundo DataTable optimizado para validar y combinar. Este segundo DataTable objeto contiene solo los DataTable objetos y DataRow que se cambiaron, lo que da lugar a un subconjunto del original DataTable. Este subconjunto suele ser más pequeño y, por lo tanto, este subconjunto se pasa de forma más eficaz a un componente de nivel intermedio. A continuación, el componente de nivel intermedio actualiza el origen de datos original con los cambios a través de procedimientos almacenados. A continuación, el nivel intermedio puede devolver un nuevo DataTable que incluya datos originales y los datos más recientes del origen de datos (ejecutando de nuevo la consulta original) o puede devolver el subconjunto con los cambios realizados en él desde el origen de datos. (Por ejemplo, si el origen de datos crea automáticamente valores de clave principal únicos, estos valores se pueden propagar a la aplicación cliente). En cualquier caso, el devuelto DataTable se puede combinar de nuevo en el original DataTable de la aplicación cliente con el Merge método .

Cuando se llama al Merge método , se comparan los esquemas de los dos DataTable objetos, ya que es posible que se hayan cambiado los esquemas. Por ejemplo, en un escenario de negocio a negocio, es posible que un proceso automatizado haya agregado nuevas columnas a un esquema XML. Si el origen DataTable contiene elementos de esquema (objetos agregados DataColumn ) que faltan en el destino, los elementos de esquema se pueden agregar al destino estableciendo el missingSchemaAction argumento MissingSchemaAction.Adden . En ese caso, la combinación DataTable contiene el esquema y los datos agregados.

Después de combinar esquemas, los datos se combinan.

Al combinar un nuevo origen DataTable en el destino, las filas de origen con un DataRowState valor de Unchanged, Modifiedo Deleted coinciden con las filas de destino con los mismos valores de clave principal. Las filas de origen con un DataRowState valor de Added coinciden con las nuevas filas de destino con los mismos valores de clave principal que las nuevas filas de origen.

Consulte también

Se aplica a

Merge(DataTable, Boolean)

Combina el objeto DataTable especificado con el objeto DataTable actual, indicando si se deben conservar los cambios en el objeto DataTable actual.

public:
 void Merge(System::Data::DataTable ^ table, bool preserveChanges);
public void Merge (System.Data.DataTable table, bool preserveChanges);
member this.Merge : System.Data.DataTable * bool -> unit
Public Sub Merge (table As DataTable, preserveChanges As Boolean)

Parámetros

table
DataTable

Objeto DataTable que se va a combinar con el objeto DataTable actual.

preserveChanges
Boolean

true para conservar los cambios realizados en el objeto DataTable actual; de lo contrario, false.

Ejemplos

La siguiente aplicación de consola crea una DataTable clase que contiene filas, modifica algunos de los datos de esas filas e intenta combinar datos de otro .DataTable En el ejemplo se muestran los distintos comportamientos del preserveChanges parámetro .


private static void DemonstrateMergeTable()
{
    // Demonstrate merging, within and without
    // preserving changes.

    // In this example, take these actions:
    // 1. Create a DataTable (table1) and fill the table with data.
    // 2. Create a copy of table1, and modify its data (modifiedTable).
    // 3. Modify data in table1.
    // 4. Make a copy of table1 (table1Copy).
    // 5. Merge the data from modifiedTable into table1 and table1Copy,
    //    showing the difference between setting the preserveChanges
    //    parameter to true and false.

    // Create a new DataTable.
    DataTable table1 = new DataTable("Items");

    // Add two columns to the table:
    DataColumn column = new DataColumn("id", typeof(System.Int32));
    column.AutoIncrement = true;
    table1.Columns.Add(column);

    column = new DataColumn("item", typeof(System.String));
    table1.Columns.Add(column);

    // Set primary key column.
    table1.PrimaryKey = new DataColumn[] { table1.Columns[0] };

    // Add some rows.
    DataRow row;
    for (int i = 0; i <= 3; i++)
    {
        row = table1.NewRow();
        row["item"] = "Item " + i;
        table1.Rows.Add(row);
    }

    // Accept changes.
    table1.AcceptChanges();
    PrintValues(table1, "Original values");

    // Using the same schema as the original table,
    // modify the data for later merge.
    DataTable modifiedTable = table1.Copy();
    foreach (DataRow rowModified in modifiedTable.Rows)
    {
        rowModified["item"] = rowModified["item"].ToString()
            + " modified";
    }
    modifiedTable.AcceptChanges();

    // Change row values, and add a new row:
    table1.Rows[0]["item"] = "new Item 0";
    table1.Rows[1]["item"] = "new Item 1";

    row = table1.NewRow();
    row["id"] = 4;
    row["item"] = "Item 4";
    table1.Rows.Add(row);

    // Get a copy of the modified data:
    DataTable table1Copy = table1.Copy();
    PrintValues(table1, "Modified and new Values");
    PrintValues(modifiedTable, "Data to be merged into table1");

    // Merge new data into the modified data.
    table1.Merge(modifiedTable, true);
    PrintValues(table1, "Merged data (preserve changes)");

    table1Copy.Merge(modifiedTable, false);
    PrintValues(table1Copy, "Merged data (don't preserve changes)");
}

private static void PrintValues(DataTable table, string label)
{
    // Display the values in the supplied DataTable:
    Console.WriteLine(label);
    foreach (DataRow row in table.Rows)
    {
        foreach (DataColumn column in table.Columns)
        {
            Console.Write("\t{0}", row[column, DataRowVersion.Current]);
        }
        Console.WriteLine();
    }
}
Private Sub DemonstrateMergeTable()
  ' Demonstrate merging, within and without
  ' preserving changes.

  ' In this example, take these actions:
  ' 1. Create a DataTable (table1) and fill the table with data.
  ' 2. Create a copy of table1, and modify its data (modifiedTable).
  ' 3. Modify data in table1.
  ' 4. Make a copy of table1 (table1Copy).
  ' 5. Merge the data from modifiedTable into table1 and table1Copy, 
  '    showing the difference between setting the preserveChanges 
  '    parameter to true and false.

  ' Create a new DataTable.
  Dim table1 As New DataTable("Items")

  ' Add two columns to the table:
  Dim column As New DataColumn("id", GetType(System.Int32))
  column.AutoIncrement = True
  table1.Columns.Add(column)

  column = New DataColumn("item", GetType(System.String))
  table1.Columns.Add(column)

  ' Set primary key column.
  table1.PrimaryKey = New DataColumn() {table1.Columns(0)}

  ' Add some rows.
  Dim row As DataRow
  For i As Integer = 0 To 3
    row = table1.NewRow()
    row("item") = "Item " & i
    table1.Rows.Add(row)
  Next i

  ' Accept changes.
  table1.AcceptChanges()
  PrintValues(table1, "Original values")

  ' Using the same schema as the original table, 
  ' modify the data for later merge.
  Dim modifiedTable As DataTable = table1.Copy()
  For Each row In modifiedTable.Rows
    row("item") = row("item").ToString() & " modified"
  Next
  modifiedTable.AcceptChanges()

  ' Change row values, and add a new row:
  table1.Rows(0)("item") = "New Item 0"
  table1.Rows(1)("item") = "New Item 1"

  row = table1.NewRow()
  row("id") = 4
  row("item") = "Item 4"
  table1.Rows.Add(row)

  ' Get a copy of the modified data:
  Dim table1Copy As DataTable = table1.Copy()
  PrintValues(table1, "Modified and New Values")
  PrintValues(modifiedTable, "Data to be merged into table1")


  ' Merge new data into the modified data.
  table1.Merge(modifiedTable, True)
  PrintValues(table1, "Merged data (preserve changes)")

  table1Copy.Merge(modifiedTable, False)
  PrintValues(table1Copy, "Merged data (don't preserve changes)")

End Sub

Private Sub PrintValues(ByVal table As DataTable, _
  ByVal label As String)

  ' Display the values in the supplied DataTable:
  Console.WriteLine(label)
  For Each row As DataRow In table.Rows
    For Each column As DataColumn In table.Columns
      Console.Write("{0}{1}", ControlChars.Tab, row(column, _
          DataRowVersion.Current))
    Next column
    Console.WriteLine()
  Next row
End Sub

Comentarios

El método Merge se usa para combinar dos DataTable objetos que tienen esquemas muy similares. Normalmente, una combinación se usa en una aplicación cliente para incorporar los cambios más recientes de un origen de datos en un existente DataTable. Esto permite que la aplicación cliente tenga una actualización DataTable con los datos más recientes del origen de datos.

La operación de combinación solo tiene en cuenta la tabla original y la tabla que se va a combinar. Las tablas secundarias no se ven afectadas ni se incluyen. Si una tabla tiene una o varias tablas secundarias, definidas como parte de una relación, cada tabla secundaria debe combinarse individualmente.

Normalmente Merge , se llama al método al final de una serie de procedimientos que implican la validación de cambios, la conciliación de errores, la actualización del origen de datos con los cambios y, por último, la actualización del existente DataTable.

Al realizar una combinación, los cambios realizados en los datos existentes antes de conservar la combinación durante la operación de combinación a menos que el desarrollador especifique false para el preserveChanges parámetro . Si el preserveChanges parámetro se establece trueen , los valores entrantes no sobrescriben los valores existentes en la versión de fila actual de la fila existente. Si el preserveChanges parámetro se establece falseen , los valores entrantes sobrescriben los valores existentes en la versión de fila actual de la fila existente. Para obtener más información sobre las versiones de fila, vea Estados de fila y Versiones de fila.

En una aplicación cliente, es habitual tener un solo botón en el que el usuario pueda hacer clic que recopile los datos modificados y lo valide antes de volver a enviarlo a un componente de nivel intermedio. En este escenario, primero se invoca el GetChanges método . Ese método devuelve un segundo DataTable optimizado para validar y combinar. Este segundo DataTable objeto contiene solo los DataTable objetos y DataRow que se cambiaron, lo que da lugar a un subconjunto del original DataTable. Este subconjunto suele ser más pequeño y, por lo tanto, este subconjunto se pasa de forma más eficaz a un componente de nivel intermedio. A continuación, el componente de nivel intermedio actualiza el origen de datos original con los cambios a través de procedimientos almacenados. A continuación, el nivel intermedio puede devolver un nuevo DataTable que incluya datos originales y los datos más recientes del origen de datos (ejecutando de nuevo la consulta original) o puede devolver el subconjunto con los cambios realizados en él desde el origen de datos. (Por ejemplo, si el origen de datos crea automáticamente valores de clave principal únicos, estos valores se pueden propagar a la aplicación cliente). En cualquier caso, el devuelto DataTable se puede combinar de nuevo en el original DataTable de la aplicación cliente con el Merge método .

Al combinar un nuevo origen DataTable en el destino, las filas de origen con un DataRowState valor de Unchanged, Modifiedo Deleted coinciden con las filas de destino con los mismos valores de clave principal. Las filas de origen con un DataRowState valor de Added coinciden con las nuevas filas de destino con los mismos valores de clave principal que las nuevas filas de origen.

Consulte también

Se aplica a

Merge(DataTable)

Combina el objeto DataTable especificado con el objeto DataTable actual.

public:
 void Merge(System::Data::DataTable ^ table);
public void Merge (System.Data.DataTable table);
member this.Merge : System.Data.DataTable -> unit
Public Sub Merge (table As DataTable)

Parámetros

table
DataTable

Objeto DataTable que se va a combinar con el objeto DataTable actual.

Ejemplos

La siguiente aplicación de consola crea un sencillo DataTable y agrega datos a la tabla. A continuación, en el ejemplo se crea una copia de la tabla y se agregan filas a la copia. Por último, el ejemplo llama al Merge método para combinar los datos de la segunda tabla con los datos de la primera tabla.

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

Comentarios

El método Merge se usa para combinar dos DataTable objetos que tienen esquemas muy similares. Normalmente, una combinación se usa en una aplicación cliente para incorporar los cambios más recientes de un origen de datos en un existente DataTable. Esto permite que la aplicación cliente tenga una actualización DataTable con los datos más recientes del origen de datos.

La operación de combinación solo tiene en cuenta la tabla original y la tabla que se va a combinar. Las tablas secundarias no se ven afectadas ni se incluyen. Si una tabla tiene una o varias tablas secundarias, definidas como parte de una relación, cada tabla secundaria debe combinarse individualmente.

Normalmente Merge , se llama al método al final de una serie de procedimientos que implican la validación de cambios, la conciliación de errores, la actualización del origen de datos con los cambios y, por último, la actualización del existente DataTable.

Al realizar una combinación, los cambios realizados en los datos existentes antes de conservar la combinación se conservan de forma predeterminada durante la operación de combinación. Los desarrolladores pueden modificar este comportamiento llamando a una de las otras dos sobrecargas para este método y especificando un valor false para el preserveChanges parámetro .

En una aplicación cliente, es habitual tener un solo botón en el que el usuario pueda hacer clic que recopile los datos modificados y lo valide antes de volver a enviarlo a un componente de nivel intermedio. En este escenario, primero se invoca el GetChanges método . Ese método devuelve un segundo DataTable optimizado para validar y combinar. Este segundo DataTable objeto contiene solo los DataRow objetos que se cambiaron, lo que da lugar a un subconjunto del original DataTable. Este subconjunto suele ser más pequeño y, por tanto, se pasa de nuevo de forma más eficaz a un componente de nivel intermedio. A continuación, el componente de nivel intermedio actualiza el origen de datos original con los cambios a través de procedimientos almacenados. A continuación, el nivel intermedio puede devolver un nuevo DataTable que incluya datos originales y los datos más recientes del origen de datos (ejecutando de nuevo la consulta original) o puede devolver el subconjunto con los cambios realizados en él desde el origen de datos. (Por ejemplo, si el origen de datos crea automáticamente valores de clave principal únicos, estos valores se pueden propagar a la aplicación cliente). En cualquier caso, el devuelto DataTable se puede combinar de nuevo en el original DataTable de la aplicación cliente con el Merge método .

Al combinar un nuevo origen DataTable en el destino, cualquier fila de origen con un DataRowState valor de Unchanged, Modifiedo Deleted, coincide con las filas de destino con los mismos valores de clave principal. Las filas de origen con un DataRowState valor de Added coinciden con las nuevas filas de destino con los mismos valores de clave principal que las nuevas filas de origen.

Consulte también

Se aplica a