DataTable.Merge DataTable.Merge DataTable.Merge DataTable.Merge Method

정의

지정된 DataTable을 현재 DataTable과 병합합니다.Merge the specified DataTable with the current DataTable.

오버로드

Merge(DataTable, Boolean, MissingSchemaAction) Merge(DataTable, Boolean, MissingSchemaAction) Merge(DataTable, Boolean, MissingSchemaAction)

지정된 DataTable을 현재 DataTable과 병합하여, 변경 내용을 유지할지 여부와 현재 DataTable의 누락된 스키마 처리 방식을 나타냅니다.Merge the specified DataTable with the current DataTable, indicating whether to preserve changes and how to handle missing schema in the current DataTable.

Merge(DataTable, Boolean) Merge(DataTable, Boolean) Merge(DataTable, Boolean) Merge(DataTable, Boolean)

지정된 DataTable을 현재 DataTable과 병합하여 현재 DataTable에서 변경 내용을 유지할지 여부를 나타냅니다.Merge the specified DataTable with the current DataTable, indicating whether to preserve changes in the current DataTable.

Merge(DataTable) Merge(DataTable) Merge(DataTable) Merge(DataTable)

지정된 DataTable을 현재 DataTable과 병합합니다.Merge the specified DataTable with the current DataTable.

예제

다음 콘솔 응용 프로그램의 동작을 보여 줍니다.는 missingSchemaAction 의 매개 변수는 Merge 메서드.The following console application demonstrates the behavior of the missingSchemaAction parameter of the Merge method. 이 예제에서는 두 번째 버전에 대 한 스키마를 수정 하는 동일한 테이블의 두 버전을 만듭니다.This example creates two versions of the same table, modifying the schema for the second version. 코드를 첫 번째 두 번째 테이블을 병합 하려고 시도 합니다.The code then attempts to merge the second table into the first.

참고

이 예에서는 병합의 오버 로드 된 버전 중 하나를 사용 하는 방법을 보여 줍니다.This example shows how to use one of the overloaded versions of Merge. 사용할 수 있는 다른 예제를 오버 로드 개별 항목을 참조 하십시오.For other examples that might be available, see the individual overload topics.

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

설명

합니다 Merge 메서드는 두 개의 병합 데 DataTable 아주 비슷한 스키마가 포함 된 개체입니다.The Merge method is used to merge two DataTable objects that have largely similar schemas. 병합을 일반적으로 사용 됩니다 클라이언트 응용 프로그램에서 데이터 원본에서 최신 변경 내용을 기존 통합할 DataTable합니다.A merge is typically used on a client application to incorporate the latest changes from a data source into an existing DataTable. 이렇게 하면 클라이언트 응용 프로그램을 새로 고칠 수 있습니다. DataTable 데이터 원본의 최신 데이터를 사용 하 여 합니다.This allows the client application to have a refreshed DataTable with the latest data from the data source.

병합 작업은 원래 테이블만 및 병합할 테이블 고려 합니다.The merge operation takes into account only the original table, and the table to be merged. 자식 테이블을 받는 되지 않거나 포함 합니다.Child tables are not affected or included. 테이블 관계의 일부로 정의 된 하나 이상의 자식 테이블에 각 자식 테이블을 개별적으로 병합 되어야 합니다.If a table has one or more child tables, defined as part of a relationship, each child table must be merged individually.

Merge(DataTable, Boolean, MissingSchemaAction) Merge(DataTable, Boolean, MissingSchemaAction) Merge(DataTable, Boolean, MissingSchemaAction)

지정된 DataTable을 현재 DataTable과 병합하여, 변경 내용을 유지할지 여부와 현재 DataTable의 누락된 스키마 처리 방식을 나타냅니다.Merge the specified DataTable with the current DataTable, indicating whether to preserve changes and how to handle missing schema in the current 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

매개 변수

table
DataTable DataTable DataTable DataTable

현재 DataTable과 병합할 DataTable입니다.The DataTable to be merged with the current DataTable.

preserveChanges
Boolean Boolean Boolean Boolean

현재 true의 변경 내용을 유지하려면 DataTable이고, 그렇지 않으면 false입니다.true, to preserve changes in the current DataTable; otherwise false.

예제

다음 콘솔 응용 프로그램의 동작을 보여 줍니다.는 missingSchemaAction 의 매개 변수는 Merge 메서드.The following console application demonstrates the behavior of the missingSchemaAction parameter of the Merge method. 이 예제에서는 두 번째 버전에 대 한 스키마를 수정 하는 동일한 테이블의 두 버전을 만듭니다.This example creates two versions of the same table, modifying the schema for the second version. 코드를 첫 번째 두 번째 테이블을 병합 하려고 시도 합니다.The code then attempts to merge the second table into the first.

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

설명

합니다 Merge 메서드는 두 개의 병합 데 DataTable 아주 비슷한 스키마가 포함 된 개체입니다.The Merge method is used to merge two DataTable objects that have largely similar schemas. 병합을 일반적으로 사용 됩니다 클라이언트 응용 프로그램에서 데이터 원본에서 최신 변경 내용을 기존 통합할 DataTable합니다.A merge is typically used on a client application to incorporate the latest changes from a data source into an existing DataTable. 이렇게 하면 클라이언트 응용 프로그램을 새로 고칠 수 있습니다. DataTable 데이터 원본의 최신 데이터를 사용 하 여 합니다.This allows the client application to have a refreshed DataTable with the latest data from the data source.

병합 작업은 원래 테이블만 및 병합할 테이블 고려 합니다.The merge operation takes into account only the original table, and the table to be merged. 자식 테이블을 받는 되지 않거나 포함 합니다.Child tables are not affected or included. 테이블 관계의 일부로 정의 된 하나 이상의 자식 테이블에 각 자식 테이블을 개별적으로 병합 되어야 합니다.If a table has one or more child tables, defined as part of a relationship, each child table must be merged individually.

합니다 Merge 메서드는 일반적으로 일련의 변경 내용의 유효성 검사, 오류 조정, 변경 내용을 사용 하 여 데이터 소스를 업데이트 및 마지막으로 기존 새로 고침을 포함 하는 절차의 끝에 호출 DataTable합니다.The Merge method is typically called at the end of a series of procedures that involve validating changes, reconciling errors, updating the data source with the changes, and finally refreshing the existing DataTable.

개발자에 대해서는 false를 지정 하지 않은 경우 병합 하기 전에 기존 데이터에 대 한 변경 내용을 병합 작업 동안 유지 됩니다 병합을 수행 하는 경우는 preserveChanges 매개 변수입니다.When performing a merge, changes made to the existing data before the merge are preserved during the merge operation unless the developer specifies false for the preserveChanges parameter. 경우는 preserveChanges 매개 변수는 설정 true을 들어오는 값이 기존 행의 현재 행 버전의 기존 값을 덮어쓰지 않습니다.If the preserveChanges parameter is set to true, incoming values do not overwrite existing values in the Current row version of the existing row. 경우는 preserveChanges 매개 변수는 설정 false을 들어오는 값이 기존 행의 현재 행 버전의 기존 값을 덮어씁니다.If the preserveChanges parameter is set to false, incoming values do overwrite the existing values in the Current row version of the existing row. 행 버전에 대 한 자세한 내용은 참조 하세요. 행 상태 및 행 버전합니다.For more information about row versions, see Row States and Row Versions.

클라이언트 응용 프로그램에서는 단일 하는 단추가 사용자가 클릭할 수 있는 변경된 된 데이터를 수집 하 고 중간 계층 구성 요소를 다시 보내기 전에 유효성 검사를 수행 하는 데 평소 됩니다.In a client application, it is usual to have a single button that the user can click that gathers the changed data and validates it before sending it back to a middle tier component. 이 시나리오에서는 GetChanges 메서드가 먼저 호출 됩니다.In this scenario, the GetChanges method is first invoked. 이 메서드는 두 번째 DataTable 유효성 검사 및 병합에 대해 최적화 합니다.That method returns a second DataTable optimized for validating and merging. 이 두 번째 DataTable 개체만 포함 된 DataTableDataRow 원래의 하위 집합에 변경 된 개체 DataTable합니다.This second DataTable object contains only the DataTable and DataRow objects that were changed, resulting in a subset of the original DataTable. 이 하위 집합은 일반적으로 작은 및 따라서이 하위 집합은 보다 효율적으로 중간 계층 구성 요소에 다시 전달 합니다.This subset is generally smaller, and thus this subset is more efficiently passed back to a middle tier component. 중간 계층 구성 요소는 다음 저장된 프로시저를 통해 변경 내용을 사용 하 여 원본 데이터 소스를 업데이트합니다.The middle tier component then updates the original data source with the changes through stored procedures. 중간 계층을 새 다시 보낼 수 있습니다 DataTable 포함 하는 원본 데이터와 데이터 원본의 최신 데이터를 (다시 실행 하 여 원래 쿼리), 또는 데이터 원본에서 변경 된 내용이 있는 하위 집합을 클라이언트로 보낼 수 있습니다.The middle tier can then send back either a new DataTable that includes original data and the latest data from the data source (by running the original query again), or it can send back the subset with any changes that have been made to it from the data source. (예를 들어, 데이터 원본에서 자동으로 고유 기본 키 값을 만드는 경우 이러한 값에 전파할 수 다시 클라이언트 응용 프로그램입니다.) 두 경우 모두 반환 된 DataTable 클라이언트 응용 프로그램의 원본에 다시 병합할 수 있게 DataTable 사용 하 여는 Merge 메서드.(For example, if the data source automatically creates unique primary key values, these values can be propagated back to the client application.) In either case, the returned DataTable can be merged back into the client application's original DataTable with the Merge method.

경우는 Merge 메서드가 호출 되는 두 스키마 DataTable 개체는 스키마 변경 수 있기 때문에 비교 됩니다.When the Merge method is called, the schemas of the two DataTable objects are compared, because it is possible that the schemas may have been changed. 예를 들어, 기업 간 시나리오에서 새 열 추가한 XML 스키마에 자동화 된 프로세스에 의해 합니다.For example, in a business-to-business scenario, new columns may have been added to an XML schema by an automated process. 하는 경우 원본 DataTable 스키마 요소를 포함 (추가 DataColumn 개체) 대상에 누락 된를 설정 하 여 대상 스키마 요소를 추가할 수 있습니다 합니다 missingSchemaAction 인수를 MissingSchemaAction.Add입니다.If the source DataTable contains schema elements (added DataColumn objects) that are missing in the target, the schema elements can be added to the target by setting the missingSchemaAction argument to MissingSchemaAction.Add. 병합 된 경우에서 DataTable 추가 된 스키마 및 데이터를 포함 합니다.In that case, the merged DataTable contains the added schema and data.

스키마를 병합 한 후 데이터를 병합 합니다.After merging schemas, the data is merged.

새 소스를 병합할 때 DataTable 을 대상으로 사용 하 여 모든 원본 행을 DataRowState 의 값 UnchangedModified, 또는 Deleted 동일한 기본 키 값을 사용 하 여 대상 행에 일치 하는 합니다.When merging a new source DataTable into the target, any source rows with a DataRowState value of Unchanged, Modified, or Deleted are matched to target rows with the same primary key values. 소스 행을 DataRowState 의 값 Added 새 원본 행과 동일한 기본 키 값을 사용 하 여 새 대상 행에 대응 됩니다.Source rows with a DataRowState value of Added are matched to new target rows with the same primary key values as the new source rows.

추가 정보

Merge(DataTable, Boolean) Merge(DataTable, Boolean) Merge(DataTable, Boolean) Merge(DataTable, Boolean)

지정된 DataTable을 현재 DataTable과 병합하여 현재 DataTable에서 변경 내용을 유지할지 여부를 나타냅니다.Merge the specified DataTable with the current DataTable, indicating whether to preserve changes in the current 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)

매개 변수

table
DataTable DataTable DataTable DataTable

현재 DataTable과 병합할 DataTable입니다.The DataTable to be merged with the current DataTable.

preserveChanges
Boolean Boolean Boolean Boolean

현재 true의 변경 내용을 유지하려면 DataTable이고, 그렇지 않으면 false입니다.true, to preserve changes in the current DataTable; otherwise false.

예제

다음 콘솔 응용 프로그램을 만듭니다는 DataTable 해당 행의 데이터 중 일부를 수정 행을 포함 하 고 다른 데이터를 병합 하려고 DataTable합니다.The following console application creates a DataTable containing rows, modifies some of the data in those rows, and attempts to merge data from a different DataTable. 예제에 대 한 다양 한 동작에는 preserveChanges 매개 변수입니다.The example demonstrates the different behaviors for the preserveChanges parameter.


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(modifiedTable, "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(modifiedTable, "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

설명

Merge 메서드는 두 개의 병합 데 DataTable 아주 비슷한 스키마가 포함 된 개체입니다.The Merge method is used to merge two DataTable objects that have largely similar schemas. 병합을 일반적으로 사용 됩니다 클라이언트 응용 프로그램에서 데이터 원본에서 최신 변경 내용을 기존 통합할 DataTable합니다.A merge is typically used on a client application to incorporate the latest changes from a data source into an existing DataTable. 이렇게 하면 클라이언트 응용 프로그램을 새로 고칠 수 있습니다. DataTable 데이터 원본의 최신 데이터를 사용 하 여 합니다.This allows the client application to have a refreshed DataTable with the latest data from the data source.

병합 작업은 원래 테이블만 및 병합할 테이블 고려 합니다.The merge operation takes into account only the original table, and the table to be merged. 자식 테이블을 받는 되지 않거나 포함 합니다.Child tables are not affected or included. 테이블 관계의 일부로 정의 된 하나 이상의 자식 테이블에 각 자식 테이블을 개별적으로 병합 되어야 합니다.If a table has one or more child tables, defined as part of a relationship, each child table must be merged individually.

합니다 Merge 메서드는 일반적으로 일련의 변경 내용의 유효성 검사, 오류 조정, 변경 내용을 사용 하 여 데이터 소스를 업데이트 및 마지막으로 기존 새로 고침을 포함 하는 절차의 끝에 호출 DataTable합니다.The Merge method is typically called at the end of a series of procedures that involve validating changes, reconciling errors, updating the data source with the changes, and finally refreshing the existing DataTable.

개발자에 대해서는 false를 지정 하지 않은 경우 병합 하기 전에 기존 데이터에 대 한 변경 내용을 병합 작업 동안 유지 됩니다 병합을 수행 하는 경우는 preserveChanges 매개 변수입니다.When performing a merge, changes made to the existing data before the merge are preserved during the merge operation unless the developer specifies false for the preserveChanges parameter. 경우는 preserveChanges 매개 변수는 설정 true을 들어오는 값이 기존 행의 현재 행 버전의 기존 값을 덮어쓰지 않습니다.If the preserveChanges parameter is set to true, incoming values do not overwrite existing values in the Current row version of the existing row. 경우는 preserveChanges 매개 변수는 설정 false을 들어오는 값이 기존 행의 현재 행 버전의 기존 값을 덮어씁니다.If the preserveChanges parameter is set to false, incoming values do overwrite the existing values in the Current row version of the existing row. 행 버전에 대 한 자세한 내용은 참조 하세요. 행 상태 및 행 버전합니다.For more information about row versions, see Row States and Row Versions.

클라이언트 응용 프로그램에서는 단일 하는 단추가 사용자가 클릭할 수 있는 변경된 된 데이터를 수집 하 고 중간 계층 구성 요소를 다시 보내기 전에 유효성 검사를 수행 하는 데 평소 됩니다.In a client application, it is usual to have a single button that the user can click that gathers the changed data and validates it before sending it back to a middle tier component. 이 시나리오에서는 GetChanges 메서드가 먼저 호출 됩니다.In this scenario, the GetChanges method is first invoked. 이 메서드는 두 번째 DataTable 유효성 검사 및 병합에 대해 최적화 합니다.That method returns a second DataTable optimized for validating and merging. 이 두 번째 DataTable 개체만 포함 된 DataTableDataRow 원래의 하위 집합에 변경 된 개체 DataTable합니다.This second DataTable object contains only the DataTable and DataRow objects that were changed, resulting in a subset of the original DataTable. 이 하위 집합은 일반적으로 작은 및 따라서이 하위 집합은 보다 효율적으로 중간 계층 구성 요소에 다시 전달 합니다.This subset is generally smaller, and thus this subset is more efficiently passed back to a middle tier component. 중간 계층 구성 요소는 다음 저장된 프로시저를 통해 변경 내용을 사용 하 여 원본 데이터 소스를 업데이트합니다.The middle tier component then updates the original data source with the changes through stored procedures. 중간 계층을 새 다시 보낼 수 있습니다 DataTable 포함 하는 원본 데이터와 데이터 원본의 최신 데이터를 (다시 실행 하 여 원래 쿼리), 또는 데이터 원본에서 변경 된 내용이 있는 하위 집합을 클라이언트로 보낼 수 있습니다.The middle tier can then send back either a new DataTable that includes original data and the latest data from the data source (by running the original query again), or it can send back the subset with any changes that have been made to it from the data source. (예를 들어, 데이터 원본에서 자동으로 고유 기본 키 값을 만드는 경우 이러한 값에 전파할 수 다시 클라이언트 응용 프로그램입니다.) 두 경우 모두 반환 된 DataTable 클라이언트 응용 프로그램의 원본에 다시 병합할 수 있게 DataTable 사용 하 여는 Merge 메서드.(For example, if the data source automatically creates unique primary key values, these values can be propagated back to the client application.) In either case, the returned DataTable can be merged back into the client application's original DataTable with the Merge method.

새 소스를 병합할 때 DataTable 을 대상으로 사용 하 여 모든 원본 행을 DataRowState 의 값 UnchangedModified, 또는 Deleted 동일한 기본 키 값을 사용 하 여 대상 행에 일치 하는 합니다.When merging a new source DataTable into the target, any source rows with a DataRowState value of Unchanged, Modified, or Deleted are matched to target rows with the same primary key values. 소스 행을 DataRowState 의 값 Added 새 원본 행과 동일한 기본 키 값을 사용 하 여 새 대상 행에 대응 됩니다.Source rows with a DataRowState value of Added are matched to new target rows with the same primary key values as the new source rows.

추가 정보

Merge(DataTable) Merge(DataTable) Merge(DataTable) Merge(DataTable)

지정된 DataTable을 현재 DataTable과 병합합니다.Merge the specified DataTable with the current DataTable.

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)

매개 변수

table
DataTable DataTable DataTable DataTable

현재 DataTable과 병합할 DataTable입니다.The DataTable to be merged with the current DataTable.

예제

다음 콘솔 응용 프로그램을 만드는 간단한 DataTable 데이터 테이블에 추가 합니다.The following console application creates a simple DataTable and adds data to the table. 다음 예제에서는 행 복사본에 추가 테이블의 복사본을 만듭니다.The example then creates a copy of the table, adding rows to the copy. 마지막으로 호출 하 여는 Merge 첫 번째 테이블의 데이터를 사용 하 여 두 번째 테이블의 데이터를 병합 하는 방법입니다.Finally, the example calls the Merge method to merge the data in the second table with the data in the first 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

설명

Merge 메서드는 두 개의 병합 데 DataTable 아주 비슷한 스키마가 포함 된 개체입니다.The Merge method is used to merge two DataTable objects that have largely similar schemas. 병합을 일반적으로 사용 됩니다 클라이언트 응용 프로그램에서 데이터 원본에서 최신 변경 내용을 기존 통합할 DataTable합니다.A merge is typically used on a client application to incorporate the latest changes from a data source into an existing DataTable. 이렇게 하면 클라이언트 응용 프로그램을 새로 고칠 수 있습니다. DataTable 데이터 원본의 최신 데이터를 사용 하 여 합니다.This allows the client application to have a refreshed DataTable with the latest data from the data source.

병합 작업은 원래 테이블만 및 병합할 테이블 고려 합니다.The merge operation takes into account only the original table, and the table to be merged. 자식 테이블을 받는 되지 않거나 포함 합니다.Child tables are not affected or included. 테이블 관계의 일부로 정의 된 하나 이상의 자식 테이블에 각 자식 테이블을 개별적으로 병합 되어야 합니다.If a table has one or more child tables, defined as part of a relationship, each child table must be merged individually.

합니다 Merge 메서드는 일반적으로 일련의 변경 내용의 유효성 검사, 오류 조정, 변경 내용을 사용 하 여 데이터 소스를 업데이트 및 마지막으로 기존 새로 고침을 포함 하는 절차의 끝에 호출 DataTable합니다.The Merge method is typically called at the end of a series of procedures that involve validating changes, reconciling errors, updating the data source with the changes, and finally refreshing the existing DataTable.

병합을 수행할 때 기존 데이터를 병합 하기 전에 변경 내용은 병합 작업 하는 동안 기본적으로 유지 됩니다.When performing a merge, changes made to the existing data before the merge are preserved by default during the merge operation. 개발자는이 메서드에 대 한 다른 두 개의 오버 로드 중 하나를 호출 하 고 false 값을 지정 하 여이 동작을 수정할 수는 preserveChanges 매개 변수입니다.Developers can modify this behavior by calling one of the other two overloads for this method, and specifying a false value for the preserveChanges parameter.

클라이언트 응용 프로그램에서는 단일 하는 단추가 사용자가 클릭할 수 있는 변경된 된 데이터를 수집 하 고 중간 계층 구성 요소를 다시 보내기 전에 유효성 검사를 수행 하는 데 평소 됩니다.In a client application, it is usual to have a single button that the user can click that gathers the changed data and validates it before sending it back to a middle tier component. 이 시나리오에서는 GetChanges 메서드가 먼저 호출 됩니다.In this scenario, the GetChanges method is first invoked. 이 메서드는 두 번째 DataTable 유효성 검사 및 병합에 대해 최적화 합니다.That method returns a second DataTable optimized for validating and merging. 이 두 번째 DataTable 개체만 포함 된 DataRow 원래의 하위 집합에 변경 된 개체 DataTable합니다.This second DataTable object contains only the DataRow objects that were changed, resulting in a subset of the original DataTable. 이 하위 집합은 일반적으로 크기가 작기 때문에 보다 효율적으로 중간 계층 구성 요소에 다시 전달 합니다.This subset is generally smaller and thus more efficiently passed back to a middle tier component. 중간 계층 구성 요소는 다음 저장된 프로시저를 통해 변경 내용을 사용 하 여 원본 데이터 소스를 업데이트합니다.The middle tier component then updates the original data source with the changes through stored procedures. 중간 계층을 새 다시 보낼 수 있습니다 DataTable 포함 하는 원본 데이터와 데이터 원본의 최신 데이터를 (다시 실행 하 여 원래 쿼리), 또는 데이터 원본에서 변경 된 내용이 있는 하위 집합을 클라이언트로 보낼 수 있습니다.The middle tier can then send back either a new DataTable that includes original data and the latest data from the data source (by running the original query again), or it can send back the subset with any changes that have been made to it from the data source. (예를 들어, 데이터 원본에서 자동으로 고유 기본 키 값을 만드는 경우 이러한 값에 전파할 수 다시 클라이언트 응용 프로그램입니다.) 두 경우 모두 반환 된 DataTable 클라이언트 응용 프로그램의 원본에 다시 병합할 수 있게 DataTable 사용 하 여는 Merge 메서드.(For example, if the data source automatically creates unique primary key values, these values can be propagated back to the client application.) In either case, the returned DataTable can be merged back into the client application's original DataTable with the Merge method.

새 소스를 병합할 때 DataTable 을 대상으로 사용 하 여 모든 원본 행을 DataRowState 의 값 UnchangedModified, 또는 Deleted, 동일한 기본 키 값을 사용 하 여 대상 행과 일치 하는 합니다.When merging a new source DataTable into the target, any source rows with a DataRowState value of Unchanged, Modified, or Deleted, is matched to target rows with the same primary key values. 소스 행을 DataRowState 의 값 Added 새 원본 행과 동일한 기본 키 값을 사용 하 여 새 대상 행에 대응 됩니다.Source rows with a DataRowState value of Added are matched to new target rows with the same primary key values as the new source rows.

추가 정보

적용 대상