> 데이터 베이스 > MySQL 튜토리얼 > C#을 사용하여 SQL 데이터베이스에 DataTable을 효율적으로 대량 삽입하려면 어떻게 해야 합니까?

C#을 사용하여 SQL 데이터베이스에 DataTable을 효율적으로 대량 삽입하려면 어떻게 해야 합니까?

Patricia Arquette
풀어 주다: 2025-01-07 22:13:43
원래의
560명이 탐색했습니다.

How Can I Efficiently Bulk Insert a DataTable into a SQL Database Using C#?

C#에서 SqlBulkCopy를 사용하여 데이터 삽입 최적화

대규모 데이터 세트의 경우 SQL Server 데이터베이스에 데이터를 행 단위로 삽입하는 것은 비효율적입니다. C#의 SqlBulkCopy 클래스는 대량 삽입 작업을 위한 훨씬 빠른 대안을 제공합니다.

대량 삽입을 위해 SqlBulkCopy 활용

SqlBulkCopy은 최적화된 단일 트랜잭션으로 대량의 데이터를 데이터베이스 테이블로 전송하도록 설계되었습니다. 구현 방법은 다음과 같습니다.

using System.Data.SqlClient;

// Establish connection and create SqlBulkCopy object
using (var bulkCopy = new SqlBulkCopy(_connection.ConnectionString, SqlBulkCopyOptions.KeepIdentity))
{
    // Map DataTable columns to database columns
    foreach (DataColumn column in table.Columns)
    {
        bulkCopy.ColumnMappings.Add(column.ColumnName, column.ColumnName);
    }

    // Specify destination table
    bulkCopy.DestinationTableName = destinationTableName;

    // Set timeout (in seconds) to prevent timeouts on large datasets
    bulkCopy.BulkCopyTimeout = 600;

    // Perform the bulk copy operation
    bulkCopy.WriteToServer(table);
}
로그인 후 복사

설명:

  • _connection.ConnectionString: 데이터베이스 연결 문자열
  • table: 삽입할 데이터가 포함된 DataTable입니다.
  • destinationTableName: SQL Server 데이터베이스에 있는 대상 테이블의 이름입니다.

중요 고려 사항:

  • 열 매핑: DataTable 열 이름이 데이터베이스 열 이름과 정확히 일치하는지 확인하세요. 서로 다른 경우 ColumnMappings를 적절하게 조정하세요.
  • ID 열: SqlBulkCopyOptions.KeepIdentityDataTable의 ID 열 값을 유지합니다.
  • 시간 초과: BulkCopyTimeout 특히 대용량 데이터 세트에 중요한 작업 시간 초과를 방지합니다. 데이터 볼륨과 네트워크 상태에 따라 필요에 따라 이 값을 조정하세요.

이 방법은 개별 행 삽입에 비해 데이터베이스 삽입 속도를 획기적으로 향상시켜 대규모 데이터 세트를 처리할 때 애플리케이션 성능을 크게 향상시킵니다.

위 내용은 C#을 사용하여 SQL 데이터베이스에 DataTable을 효율적으로 대량 삽입하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿