Partage via


DataTable.Merge Méthode

Définition

Fusionnez le DataTable spécifié avec le DataTable actuel.

Surcharges

Merge(DataTable, Boolean, MissingSchemaAction)

Fusionnez le DataTable spécifié avec le DataTable actuel, en indiquant s'il faut conserver les modifications et comment gérer le schéma manquant dans le DataTable actuel.

Merge(DataTable, Boolean)

Fusionnez le DataTable spécifié avec le DataTable actuel, en indiquant s'il faut conserver les modifications dans le DataTable actuel.

Merge(DataTable)

Fusionnez le DataTable spécifié avec le DataTable actuel.

Exemples

L’application console suivante illustre le comportement du missingSchemaAction paramètre de la Merge méthode . Cet exemple crée deux versions de la même table, en modifiant le schéma de la deuxième version. Le code tente ensuite de fusionner la deuxième table dans la première.

Notes

Cet exemple montre comment utiliser l’une des versions surchargées de Merge. Pour obtenir d’autres exemples qui peuvent être disponibles, consultez les rubriques sur les surcharges individuelles.

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

Remarques

La Merge méthode est utilisée pour fusionner deux DataTable objets qui ont des schémas largement similaires. Une fusion est généralement utilisée sur une application cliente pour incorporer les dernières modifications d’une source de données dans une DataTable. Cela permet à l’application cliente DataTable d’avoir un actualisé avec les dernières données de la source de données.

L’opération de fusion prend uniquement en compte la table d’origine et la table à fusionner. Les tables enfants ne sont pas affectées ou incluses. Si une table a une ou plusieurs tables enfants, définies dans le cadre d’une relation, chaque table enfant doit être fusionnée individuellement.

Merge(DataTable, Boolean, MissingSchemaAction)

Source:
DataTable.cs
Source:
DataTable.cs
Source:
DataTable.cs

Fusionnez le DataTable spécifié avec le DataTable actuel, en indiquant s'il faut conserver les modifications et comment gérer le schéma manquant dans le DataTable actuel.

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)

Paramètres

table
DataTable

DataTable à fusionner avec le DataTable actuel.

preserveChanges
Boolean

true pour préserver les modifications apportées au DataTable en cours ; sinon, false.

missingSchemaAction
MissingSchemaAction

Une des valeurs de l'objet MissingSchemaAction.

Exemples

L’application console suivante illustre le comportement du missingSchemaAction paramètre de la Merge méthode . Cet exemple crée deux versions de la même table, en modifiant le schéma de la deuxième version. Le code tente ensuite de fusionner la deuxième table dans la première.

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

Remarques

La Merge méthode est utilisée pour fusionner deux DataTable objets qui ont des schémas largement similaires. Une fusion est généralement utilisée sur une application cliente pour incorporer les dernières modifications d’une source de données dans un existant DataTable. Cela permet à l’application cliente DataTable d’avoir un actualisé avec les données les plus récentes de la source de données.

L’opération de fusion prend uniquement en compte la table d’origine et la table à fusionner. Les tables enfants ne sont pas affectées ou incluses. Si une table a une ou plusieurs tables enfants, définies dans le cadre d’une relation, chaque table enfant doit être fusionnée individuellement.

La Merge méthode est généralement appelée à la fin d’une série de procédures qui impliquent la validation des modifications, le rapprochement des erreurs, la mise à jour de la source de données avec les modifications et enfin l’actualisation de l’existant DataTable.

Lors d’une fusion, les modifications apportées aux données existantes avant la fusion sont conservées pendant l’opération de fusion, sauf si le développeur spécifie false pour le preserveChanges paramètre. Si le preserveChanges paramètre est défini sur true, les valeurs entrantes ne remplacent pas les valeurs existantes dans la version de ligne actuelle de la ligne existante. Si le preserveChanges paramètre est défini sur false, les valeurs entrantes remplacent les valeurs existantes dans la version de ligne actuelle de la ligne existante. Pour plus d’informations sur les versions de ligne, consultez États de ligne et versions de ligne.

Dans une application cliente, il est courant d’avoir un seul bouton sur lequel l’utilisateur peut cliquer pour collecter les données modifiées et les valider avant de les renvoyer à un composant de niveau intermédiaire. Dans ce scénario, la GetChanges méthode est d’abord appelée. Cette méthode retourne une seconde DataTable optimisée pour la validation et la fusion. Ce deuxième DataTable objet contient uniquement les DataTable objets et DataRow qui ont été modifiés, ce qui aboutit à un sous-ensemble du DataTable. Ce sous-ensemble est généralement plus petit et, par conséquent, ce sous-ensemble est repassé plus efficacement à un composant de niveau intermédiaire. Le composant de niveau intermédiaire met ensuite à jour la source de données d’origine avec les modifications par le biais de procédures stockées. Le niveau intermédiaire peut ensuite renvoyer un nouveau DataTable qui inclut les données d’origine et les données les plus récentes de la source de données (en exécutant à nouveau la requête d’origine), ou renvoyer le sous-ensemble avec toutes les modifications qui lui ont été apportées à partir de la source de données. (Par exemple, si la source de données crée automatiquement des valeurs de clé primaire uniques, ces valeurs peuvent être propagées à l’application cliente.) Dans les deux cas, le retourné DataTable peut être fusionné dans l’original DataTable de l’application cliente avec la Merge méthode .

Lorsque la Merge méthode est appelée, les schémas des deux DataTable objets sont comparés, car il est possible que les schémas aient été modifiés. Par exemple, dans un scénario interentreprises, de nouvelles colonnes peuvent avoir été ajoutées à un schéma XML par un processus automatisé. Si la source DataTable contient des éléments de schéma (objets ajoutés DataColumn ) manquants dans la cible, les éléments de schéma peuvent être ajoutés à la cible en définissant l’argument missingSchemaAction sur MissingSchemaAction.Add. Dans ce cas, le fusionné DataTable contient le schéma et les données ajoutés.

Après la fusion des schémas, les données sont fusionnées.

Lors de Unchangedla fusion d’une nouvelle source DataTable dans la cible, toutes les lignes sources dont DataRowState la valeur est , Modifiedou Deleted sont mises en correspondance avec les lignes cibles avec les mêmes valeurs de clé primaire. Les lignes sources avec une DataRowState valeur de Added sont mises en correspondance avec les nouvelles lignes cibles avec les mêmes valeurs de clé primaire que les nouvelles lignes sources.

Voir aussi

S’applique à

Merge(DataTable, Boolean)

Source:
DataTable.cs
Source:
DataTable.cs
Source:
DataTable.cs

Fusionnez le DataTable spécifié avec le DataTable actuel, en indiquant s'il faut conserver les modifications dans le DataTable actuel.

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)

Paramètres

table
DataTable

DataTable à fusionner avec le DataTable actuel.

preserveChanges
Boolean

true pour préserver les modifications apportées au DataTable en cours ; sinon, false.

Exemples

L’application console suivante crée un DataTable contenant des lignes, modifie certaines des données de ces lignes et tente de fusionner les données d’un autre DataTable. L’exemple illustre les différents comportements du preserveChanges paramètre .


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

Remarques

La méthode Merge est utilisée pour fusionner deux DataTable objets qui ont des schémas largement similaires. Une fusion est généralement utilisée sur une application cliente pour incorporer les dernières modifications d’une source de données dans un existant DataTable. Cela permet à l’application cliente DataTable d’avoir un actualisé avec les données les plus récentes de la source de données.

L’opération de fusion prend uniquement en compte la table d’origine et la table à fusionner. Les tables enfants ne sont pas affectées ou incluses. Si une table a une ou plusieurs tables enfants, définies dans le cadre d’une relation, chaque table enfant doit être fusionnée individuellement.

La Merge méthode est généralement appelée à la fin d’une série de procédures qui impliquent la validation des modifications, le rapprochement des erreurs, la mise à jour de la source de données avec les modifications et enfin l’actualisation de l’existant DataTable.

Lors d’une fusion, les modifications apportées aux données existantes avant la fusion sont conservées pendant l’opération de fusion, sauf si le développeur spécifie false pour le preserveChanges paramètre. Si le preserveChanges paramètre est défini sur true, les valeurs entrantes ne remplacent pas les valeurs existantes dans la version de ligne actuelle de la ligne existante. Si le preserveChanges paramètre est défini sur false, les valeurs entrantes remplacent les valeurs existantes dans la version de ligne actuelle de la ligne existante. Pour plus d’informations sur les versions de ligne, consultez États de ligne et versions de ligne.

Dans une application cliente, il est courant d’avoir un seul bouton sur lequel l’utilisateur peut cliquer pour collecter les données modifiées et les valider avant de les renvoyer à un composant de niveau intermédiaire. Dans ce scénario, la GetChanges méthode est d’abord appelée. Cette méthode retourne une seconde DataTable optimisée pour la validation et la fusion. Ce deuxième DataTable objet contient uniquement les DataTable objets et DataRow qui ont été modifiés, ce qui aboutit à un sous-ensemble du DataTable. Ce sous-ensemble est généralement plus petit et, par conséquent, ce sous-ensemble est repassé plus efficacement à un composant de niveau intermédiaire. Le composant de niveau intermédiaire met ensuite à jour la source de données d’origine avec les modifications par le biais de procédures stockées. Le niveau intermédiaire peut ensuite renvoyer un nouveau DataTable qui inclut les données d’origine et les données les plus récentes de la source de données (en exécutant à nouveau la requête d’origine), ou renvoyer le sous-ensemble avec toutes les modifications qui lui ont été apportées à partir de la source de données. (Par exemple, si la source de données crée automatiquement des valeurs de clé primaire uniques, ces valeurs peuvent être propagées à l’application cliente.) Dans les deux cas, le retourné DataTable peut être fusionné dans l’original DataTable de l’application cliente avec la Merge méthode .

Lors de Unchangedla fusion d’une nouvelle source DataTable dans la cible, toutes les lignes sources dont DataRowState la valeur est , Modifiedou Deleted sont mises en correspondance avec les lignes cibles avec les mêmes valeurs de clé primaire. Les lignes sources avec une DataRowState valeur de Added sont mises en correspondance avec les nouvelles lignes cibles avec les mêmes valeurs de clé primaire que les nouvelles lignes sources.

Voir aussi

S’applique à

Merge(DataTable)

Source:
DataTable.cs
Source:
DataTable.cs
Source:
DataTable.cs

Fusionnez le DataTable spécifié avec le DataTable actuel.

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)

Paramètres

table
DataTable

DataTable à fusionner avec le DataTable actuel.

Exemples

L’application console suivante crée un simple DataTable et ajoute des données à la table. L’exemple crée ensuite une copie de la table, en ajoutant des lignes à la copie. Enfin, l’exemple appelle la Merge méthode pour fusionner les données de la deuxième table avec les données de la première table.

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

Remarques

La méthode Merge est utilisée pour fusionner deux DataTable objets qui ont des schémas largement similaires. Une fusion est généralement utilisée sur une application cliente pour incorporer les dernières modifications d’une source de données dans un existant DataTable. Cela permet à l’application cliente DataTable d’avoir un actualisé avec les données les plus récentes de la source de données.

L’opération de fusion prend uniquement en compte la table d’origine et la table à fusionner. Les tables enfants ne sont pas affectées ou incluses. Si une table a une ou plusieurs tables enfants, définies dans le cadre d’une relation, chaque table enfant doit être fusionnée individuellement.

La Merge méthode est généralement appelée à la fin d’une série de procédures qui impliquent la validation des modifications, le rapprochement des erreurs, la mise à jour de la source de données avec les modifications et enfin l’actualisation de l’existant DataTable.

Lors d’une fusion, les modifications apportées aux données existantes avant la fusion sont conservées par défaut pendant l’opération de fusion. Les développeurs peuvent modifier ce comportement en appelant l’une des deux autres surcharges pour cette méthode et en spécifiant une valeur false pour le preserveChanges paramètre .

Dans une application cliente, il est courant d’avoir un seul bouton sur lequel l’utilisateur peut cliquer pour collecter les données modifiées et les valider avant de les renvoyer à un composant de niveau intermédiaire. Dans ce scénario, la GetChanges méthode est d’abord appelée. Cette méthode retourne une seconde DataTable optimisée pour la validation et la fusion. Ce deuxième DataTable objet contient uniquement les DataRow objets qui ont été modifiés, ce qui aboutit à un sous-ensemble de l’objet d’origine DataTable. Ce sous-ensemble est généralement plus petit et, par conséquent, plus efficacement repassé à un composant de niveau intermédiaire. Le composant de niveau intermédiaire met ensuite à jour la source de données d’origine avec les modifications par le biais de procédures stockées. Le niveau intermédiaire peut ensuite renvoyer un nouveau DataTable qui inclut les données d’origine et les données les plus récentes de la source de données (en exécutant à nouveau la requête d’origine), ou renvoyer le sous-ensemble avec toutes les modifications qui lui ont été apportées à partir de la source de données. (Par exemple, si la source de données crée automatiquement des valeurs de clé primaire uniques, ces valeurs peuvent être propagées à l’application cliente.) Dans les deux cas, le retourné DataTable peut être fusionné dans l’original DataTable de l’application cliente avec la Merge méthode .

Lors de Unchangedla fusion d’une nouvelle source DataTable dans la cible, toutes les lignes sources avec la DataRowState valeur , Modifiedou Deleted, sont mises en correspondance avec des lignes cibles avec les mêmes valeurs de clé primaire. Les lignes sources avec la DataRowState valeur de Added sont mises en correspondance avec les nouvelles lignes cibles avec les mêmes valeurs de clé primaire que les nouvelles lignes sources.

Voir aussi

S’applique à