DataTable.Merge Metoda

Definicja

Scal określony DataTable element z bieżącym DataTableelementem .

Przeciążenia

Merge(DataTable, Boolean, MissingSchemaAction)

Scal określony DataTable z bieżącym DataTableelementem , wskazując, czy zachować zmiany i jak obsłużyć brakujący schemat w bieżącym elemencie DataTable.

Merge(DataTable, Boolean)

Scal określony DataTable element z bieżącym DataTableelementem , wskazując, czy zachować zmiany w bieżącym elemencie DataTable.

Merge(DataTable)

Scal określony DataTable element z bieżącym DataTableelementem .

Przykłady

Poniższa aplikacja konsolowa demonstruje zachowanie missingSchemaAction parametru Merge metody. W tym przykładzie są tworzone dwie wersje tej samej tabeli, modyfikując schemat drugiej wersji. Następnie kod próbuje scalić drugą tabelę z pierwszą.

Uwaga

W tym przykładzie pokazano, jak używać jednej z przeciążonych wersji scalania. Aby zapoznać się z innymi przykładami, które mogą być dostępne, zobacz poszczególne tematy przeciążenia.

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

Uwagi

Metoda Merge służy do scalania dwóch DataTable obiektów, które mają w dużej mierze podobne schematy. Scalanie jest zwykle używane w aplikacji klienckiej w celu uwzględnienia najnowszych zmian ze źródła danych do istniejącego DataTableelementu . Dzięki temu aplikacja kliencka może odświeżyć DataTable najnowsze dane ze źródła danych.

Operacja scalania uwzględnia tylko oryginalną tabelę, a tabelę do scalenia. Tabele podrzędne nie mają wpływu ani nie są uwzględniane. Jeśli tabela ma co najmniej jedną tabelę podrzędną, zdefiniowaną jako część relacji, każda tabela podrzędna musi zostać scalona indywidualnie.

Merge(DataTable, Boolean, MissingSchemaAction)

Scal określony DataTable z bieżącym DataTableelementem , wskazując, czy zachować zmiany i jak obsłużyć brakujący schemat w bieżącym elemencie DataTable.

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)

Parametry

table
DataTable

Element DataTable do scalenia z bieżącym DataTableelementem .

preserveChanges
Boolean

true, aby zachować zmiany w bieżącym DataTable; w przeciwnym razie false.

missingSchemaAction
MissingSchemaAction

Jedna z MissingSchemaAction wartości.

Przykłady

Poniższa aplikacja konsolowa demonstruje zachowanie missingSchemaAction parametru Merge metody . W tym przykładzie są tworzone dwie wersje tej samej tabeli, modyfikując schemat dla drugiej wersji. Następnie kod próbuje scalić drugą tabelę z pierwszą.

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

Uwagi

Metoda Merge służy do scalania dwóch DataTable obiektów, które mają w dużej mierze podobne schematy. Scalanie jest zwykle używane w aplikacji klienckiej w celu uwzględnienia najnowszych zmian ze źródła danych do istniejącego DataTableelementu . Dzięki temu aplikacja kliencka może odświeżyć DataTable najnowsze dane ze źródła danych.

Operacja scalania uwzględnia tylko oryginalną tabelę i tabelę do scalenia. Nie ma to wpływu na tabele podrzędne ani nie są uwzględniane. Jeśli tabela zawiera co najmniej jedną tabelę podrzędną zdefiniowaną jako część relacji, każda tabela podrzędna musi być scalona indywidualnie.

Metoda Merge jest zwykle wywoływana na końcu serii procedur, które obejmują walidację zmian, uzgadnianie błędów, aktualizowanie źródła danych za pomocą zmian, a na koniec odświeżanie istniejącego DataTableelementu .

Podczas scalania zmiany wprowadzone w istniejących danych przed scaleniem są zachowywane podczas operacji scalania, chyba że deweloper określa wartość false dla parametru preserveChanges . preserveChanges Jeśli parametr jest ustawiony na truewartość , wartości przychodzące nie zastępują istniejących wartości w bieżącej wersji wiersza istniejącego wiersza. preserveChanges Jeśli parametr jest ustawiony na falsewartość , wartości przychodzące zastępują istniejące wartości w bieżącej wersji wiersza istniejącego wiersza. Aby uzyskać więcej informacji na temat wersji wierszy, zobacz Stany wierszy i Wersje wierszy.

W aplikacji klienckiej zwykle istnieje jeden przycisk, który użytkownik może kliknąć, aby zebrać zmienione dane i zweryfikować je przed wysłaniem go z powrotem do składnika warstwy środkowej. W tym scenariuszu metoda jest wywoływana GetChanges po raz pierwszy. Ta metoda zwraca drugą DataTable zoptymalizowaną pod kątem walidacji i scalania. Ten drugi DataTable obiekt zawiera tylko DataTable obiekty i DataRow , które zostały zmienione, co powoduje podzbiór oryginalnego DataTableobiektu . Ten podzbiór jest zazwyczaj mniejszy, dlatego ten podzbiór jest wydajniej przekazywany z powrotem do składnika warstwy środkowej. Składnik warstwy środkowej aktualizuje następnie oryginalne źródło danych ze zmianami za pomocą procedur składowanych. Warstwa środkowa może następnie wysłać z powrotem nowy DataTable , który zawiera oryginalne dane i najnowsze dane ze źródła danych (uruchamiając ponownie oryginalne zapytanie) lub może wysłać podzbiór z wszelkimi zmianami, które zostały do niego wprowadzone ze źródła danych. (Jeśli na przykład źródło danych automatycznie tworzy unikatowe wartości klucza podstawowego, te wartości można propagować z powrotem do aplikacji klienckiej). W obu przypadkach zwrócone DataTable dane można scalić z powrotem do oryginalnej DataTable aplikacji klienckiej z Merge metodą .

Merge Gdy metoda jest wywoływana, schematy dwóch DataTable obiektów są porównywane, ponieważ możliwe, że schematy mogły zostać zmienione. Na przykład w scenariuszu biznesowym do celów biznesowych nowe kolumny mogły zostać dodane do schematu XML przez zautomatyzowany proces. Jeśli źródło DataTable zawiera elementy schematu (dodane DataColumn obiekty), których brakuje w obiekcie docelowym, elementy schematu można dodać do obiektu docelowego, ustawiając missingSchemaAction argument na MissingSchemaAction.Add. W takim przypadku scalony DataTable zawiera dodany schemat i dane.

Po scaleniu schematów dane są scalane.

Podczas scalania nowego źródła DataTable z obiektem docelowym wszystkie wiersze źródłowe o DataRowState wartości Unchanged, Modifiedlub Deleted są dopasowywane do wierszy docelowych z tymi samymi wartościami klucza podstawowego. Wiersze źródłowe z wartością DataRowState Added są dopasowywane do nowych wierszy docelowych z tymi samymi wartościami klucza podstawowego co nowe wiersze źródłowe.

Zobacz też

Dotyczy

Merge(DataTable, Boolean)

Scal określony DataTable element z bieżącym DataTableelementem , wskazując, czy zachować zmiany w bieżącym elemencie DataTable.

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)

Parametry

table
DataTable

Element DataTable do scalenia z bieżącym DataTableelementem .

preserveChanges
Boolean

true, aby zachować zmiany w bieżącym DataTable; w przeciwnym razie false.

Przykłady

Poniższa aplikacja konsolowa tworzy DataTable wiersze zawierające, modyfikuje niektóre dane w tych wierszach i próbuje scalić dane z innego DataTableelementu . W przykładzie przedstawiono różne zachowania parametru preserveChanges .


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

Uwagi

Metoda Merge służy do scalania dwóch DataTable obiektów, które mają w dużej mierze podobne schematy. Scalanie jest zwykle używane w aplikacji klienckiej w celu uwzględnienia najnowszych zmian ze źródła danych do istniejącego DataTableelementu . Dzięki temu aplikacja kliencka może odświeżyć DataTable najnowsze dane ze źródła danych.

Operacja scalania uwzględnia tylko oryginalną tabelę, a tabelę do scalenia. Tabele podrzędne nie mają wpływu ani nie są uwzględniane. Jeśli tabela ma co najmniej jedną tabelę podrzędną, zdefiniowaną jako część relacji, każda tabela podrzędna musi zostać scalona indywidualnie.

Metoda Merge jest zwykle wywoływana na końcu serii procedur, które obejmują weryfikowanie zmian, uzgadnianie błędów, aktualizowanie źródła danych za pomocą zmian i odświeżanie istniejącego DataTableelementu .

Podczas scalania zmiany wprowadzone w istniejących danych przed scaleniem są zachowywane podczas operacji scalania, chyba że deweloper określa wartość false dla parametru preserveChanges . preserveChanges Jeśli parametr ma wartość true, wartości przychodzące nie zastępują istniejących wartości w bieżącej wersji wiersza istniejącego wiersza. preserveChanges Jeśli parametr ma wartość false, wartości przychodzące zastępują istniejące wartości w bieżącej wersji wiersza istniejącego wiersza. Aby uzyskać więcej informacji na temat wersji wierszy, zobacz Row States and Row Versions (Stany wierszy i wersje wierszy).

W aplikacji klienckiej zwykle jest dostępny jeden przycisk, który użytkownik może kliknąć, aby zbierał zmienione dane i weryfikuje je przed wysłaniem go z powrotem do składnika warstwy środkowej. W tym scenariuszu metoda jest wywoływana GetChanges po raz pierwszy. Ta metoda zwraca drugą DataTable zoptymalizowaną pod kątem walidacji i scalania. Ten drugi DataTable obiekt zawiera tylko DataTable obiekty i DataRow , które zostały zmienione, co powoduje podzbiór oryginalnego DataTableobiektu . Ten podzbiór jest zazwyczaj mniejszy, dlatego ten podzbiór jest wydajniej przekazywany z powrotem do składnika warstwy środkowej. Składnik warstwy środkowej aktualizuje następnie oryginalne źródło danych za pomocą zmian w procedurach składowanych. Warstwa środkowa może następnie wysłać z powrotem nowy, DataTable który zawiera oryginalne dane i najnowsze dane ze źródła danych (uruchamiając ponownie oryginalne zapytanie), lub może wysłać z powrotem podzestaw z wszelkimi zmianami, które zostały wprowadzone do niego ze źródła danych. (Jeśli na przykład źródło danych automatycznie tworzy unikatowe wartości klucza podstawowego, te wartości można propagować z powrotem do aplikacji klienckiej). W obu przypadkach zwrócone DataTable dane można scalić z powrotem do oryginalnej DataTable aplikacji klienckiej przy użyciu Merge metody .

Podczas scalania nowego źródła DataTable z obiektem docelowym wszystkie wiersze źródłowe o DataRowState wartości Unchanged, Modifiedlub Deleted są dopasowywane do wierszy docelowych z tymi samymi wartościami klucza podstawowego. Wiersze źródłowe z wartością DataRowState Added są dopasowywane do nowych wierszy docelowych z tymi samymi wartościami klucza podstawowego co nowe wiersze źródłowe.

Zobacz też

Dotyczy

Merge(DataTable)

Scal określony DataTable element z bieżącym DataTableelementem .

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)

Parametry

table
DataTable

Element DataTable do scalenia z bieżącym DataTableelementem .

Przykłady

Poniższa aplikacja konsolowa tworzy proste DataTable i dodaje dane do tabeli. Następnie przykład tworzy kopię tabeli, dodając wiersze do kopii. Na koniec przykład wywołuje metodę Merge , aby scalić dane w drugiej tabeli z danymi w pierwszej tabeli.

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

Uwagi

Metoda Merge służy do scalania dwóch DataTable obiektów, które mają w dużej mierze podobne schematy. Scalanie jest zwykle używane w aplikacji klienckiej w celu uwzględnienia najnowszych zmian ze źródła danych do istniejącego DataTableelementu . Dzięki temu aplikacja kliencka może odświeżyć DataTable najnowsze dane ze źródła danych.

Operacja scalania uwzględnia tylko oryginalną tabelę, a tabelę do scalenia. Tabele podrzędne nie mają wpływu ani nie są uwzględniane. Jeśli tabela ma co najmniej jedną tabelę podrzędną, zdefiniowaną jako część relacji, każda tabela podrzędna musi zostać scalona indywidualnie.

Metoda Merge jest zwykle wywoływana na końcu serii procedur, które obejmują weryfikowanie zmian, uzgadnianie błędów, aktualizowanie źródła danych za pomocą zmian i odświeżanie istniejącego DataTableelementu .

Podczas scalania zmiany wprowadzone w istniejących danych przed scalanie są domyślnie zachowywane podczas operacji scalania. Deweloperzy mogą modyfikować to zachowanie, wywołując jedno z dwóch pozostałych przeciążeń dla tej metody i określając wartość false dla parametru preserveChanges .

W aplikacji klienckiej zwykle jest dostępny jeden przycisk, który użytkownik może kliknąć, aby zbierał zmienione dane i weryfikuje je przed wysłaniem go z powrotem do składnika warstwy środkowej. W tym scenariuszu metoda jest wywoływana GetChanges po raz pierwszy. Ta metoda zwraca drugą DataTable zoptymalizowaną pod kątem walidacji i scalania. Ten drugi DataTable obiekt zawiera tylko DataRow obiekty, które zostały zmienione, co powoduje podzbiór oryginalnego DataTableobiektu . Ten podzbiór jest zazwyczaj mniejszy, a tym samym wydajniej przekazywany z powrotem do składnika warstwy środkowej. Składnik warstwy środkowej aktualizuje następnie oryginalne źródło danych za pomocą zmian w procedurach składowanych. Warstwa środkowa może następnie wysłać z powrotem nowy, DataTable który zawiera oryginalne dane i najnowsze dane ze źródła danych (uruchamiając ponownie oryginalne zapytanie), lub może wysłać z powrotem podzestaw z wszelkimi zmianami, które zostały wprowadzone do niego ze źródła danych. (Jeśli na przykład źródło danych automatycznie tworzy unikatowe wartości klucza podstawowego, te wartości można propagować z powrotem do aplikacji klienckiej). W obu przypadkach zwrócone DataTable dane można scalić z powrotem do oryginalnej DataTable aplikacji klienckiej przy użyciu Merge metody .

Podczas scalania nowego źródła DataTable z obiektem docelowym wszystkie wiersze źródłowe o DataRowState wartości Unchanged, Modifiedlub Deletedsą dopasowywane do wierszy docelowych z tymi samymi wartościami klucza podstawowego. Wiersze źródłowe z wartością DataRowState Added są dopasowywane do nowych wierszy docelowych z tymi samymi wartościami klucza podstawowego co nowe wiersze źródłowe.

Zobacz też

Dotyczy