>백엔드 개발 >C++ >다양한 스키마가 있는 여러 DataTable을 C#의 단일 DataTable로 효율적으로 병합하려면 어떻게 해야 합니까?

다양한 스키마가 있는 여러 DataTable을 C#의 단일 DataTable로 효율적으로 병합하려면 어떻게 해야 합니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-29 13:50:10318검색

How can I efficiently merge multiple DataTables with varying schemas into a single DataTable in C#?

가변 스키마가 있는 여러 DataTable을 단일 테이블로 결합

여러 DataTable을 단일 테이블로 결합하는 문제를 해결하려면 다음을 효과적으로 처리하는 효율적인 방법을 권장합니다. 다양한 열 구조 및 행 정렬

빠른 솔루션

다음 C# 코드 스니펫은 간단한 접근 방식을 제공합니다.

public static DataTable MergeTables(IList<DataTable> tables, string primaryKeyColumn)
{
    if (!tables.Any())
        throw new ArgumentException("Tables must not be empty", "tables");
    if (primaryKeyColumn != null)
        foreach (DataTable t in tables)
            if (!t.Columns.Contains(primaryKeyColumn))
                throw new ArgumentException("All tables must have the specified primarykey column " + primaryKeyColumn, "primaryKeyColumn");

    if (tables.Count == 1)
        return tables[0];

    DataTable table = new DataTable("TblUnion");
    table.BeginLoadData(); // Turns off notifications, index maintenance, and constraints while loading data
    foreach (DataTable t in tables)
    {
        table.Merge(t); // same as table.Merge(t, false, MissingSchemaAction.Add);
    }
    table.EndLoadData();

    if (primaryKeyColumn != null)
    {
        // join rows with repeating primary key columns
        var pkGroups = table.AsEnumerable()
            .GroupBy(r => r[primaryKeyColumn]);
        var dupGroups = pkGroups.Where(g => g.Count() > 1);
        foreach (var grpDup in dupGroups)
        { 
            // use first row and modify it
            DataRow firstRow = grpDup.First();
            foreach (DataColumn c in table.Columns)
            {
                if (firstRow.IsNull(c))
                {
                    DataRow firstNotNullRow = grpDup.Skip(1).FirstOrDefault(r => !r.IsNull(c));
                    if (firstNotNullRow != null)
                        firstRow[c] = firstNotNullRow[c];
                }
            }
            // remove all but first row
            var rowsToRemove = grpDup.Skip(1);
            foreach(DataRow rowToRemove in rowsToRemove)
                table.Rows.Remove(rowToRemove);
        }
    }

    return table;
}

사용

MergeTables 방법을 활용하려면 다음 단계를 따르세요.

  1. 입력 DataTable 목록을 정의합니다.
  2. 선택적으로 테이블이 공통 기본 키를 공유하는 경우 기본 키 열의 이름을 지정합니다. 키.
  3. 해당되는 경우 테이블 목록과 기본 키 열을 사용하여 MergeTables 메서드를 호출합니다.
  4. 이 메서드는 병합된 데이터가 포함된 단일 DataTable을 반환하여 열 구조의 불일치를 처리하고 행 정렬.

다음 샘플을 고려하세요. DataTables:

DataTable1 (Columns: c1, c2, c3, c4)
| c1 | c2 | c3 | c4 |
|---|---|---|---|
| 1 | 8500 | abc | A |
| 2 | 950 | cde | B |
| 3 | 150 | efg | C |
| 4 | 850 | ghi | D |
| 5 | 50 | ijk | E |

DataTable2 (Columns: c1, c5, c6, c7)
| c1 | c5 | c6 | c7 |
|---|---|---|---|
| 1 | 7500 | klm | F |
| 2 | 900 | mno | G |
| 3 | 150 | opq | H |
| 4 | 850 | qrs | I |
| 5 | 50 | stu | J |

DataTable3 (Columns: c1, c8, c9, c10)
| c1 | c8 | c9 | c10 |
|---|---|---|---|
| 1 | 7500 | uvw | K |
| 2 | 900 | wxy | L |
| 3 | 150 | yza | M |
| 4 | 850 | ABC | N |
| 5 | 50 | CDE | O |

이 세 테이블을 병합하려면 다음과 같이 MergeTables 메서드를 호출할 수 있습니다.

var tables = new[] { DataTable1, DataTable2, DataTable3 };
DataTable mergedTable = MergeTables(tables, "c1");

병합 테이블에는 세 입력 테이블의 모든 행이 포함됩니다. 공통 기본 키 열 "c1"로 정렬된 열입니다. 행에서 누락된 값은 동일한 기본 키 값으로 null이 아닌 첫 번째 행부터 채워집니다.

위 내용은 다양한 스키마가 있는 여러 DataTable을 C#의 단일 DataTable로 효율적으로 병합하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.