>백엔드 개발 >C++ >2백만 개의 행을 SQL Server에 효율적으로 삽입하려면 어떻게 해야 합니까?

2백만 개의 행을 SQL Server에 효율적으로 삽입하려면 어떻게 해야 합니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-21 14:46:11158검색

How Can I Efficiently Insert 2 Million Rows into SQL Server?

SQL Server 데이터베이스에 200만 행의 데이터를 효율적으로 일괄 삽입

SQL Server 데이터베이스에 대량의 데이터를 삽입하는 경우 삽입 프로세스를 최적화하는 것이 중요합니다. 이 글에서는 200만 행의 데이터를 효율적으로 삽입하는 가장 좋은 방법을 종합적으로 소개합니다.

SqlBulkCopy 사용

SqlBulkCopy 클래스는 대량 삽입에 이상적입니다. .NET DataTable 또는 IEnumerable의 데이터를 SQL Server 테이블로 직접 빠르게 전송합니다. 데이터 중심 작업을 활용함으로써 기존의 행별 삽입을 우회하고 처리 시간을 크게 단축합니다.

구현 단계

SqlBulkCopy를 효과적으로 사용하려면 다음 단계를 따르세요.

  1. SQL Server에 대한 연결을 설정합니다.
  2. 대상 테이블 이름과 원하는 옵션(예: 트리거)을 지정하여 SqlBulkCopy 인스턴스를 만듭니다.
  3. 연결을 엽니다.
  4. 데이터를 전송하려면 WriteToServer() 메서드를 사용하세요.
  5. 연결을 종료하세요.

다음은 C# 예입니다.

<code class="language-csharp">using (SqlConnection connection = new SqlConnection(connString))
{
    SqlBulkCopy bulkCopy = new SqlBulkCopy(connection, SqlBulkCopyOptions.TableLock | SqlBulkCopyOptions.FireTriggers, null);
    bulkCopy.DestinationTableName = tableName;
    connection.Open();
    bulkCopy.WriteToServer(dataTable);
    connection.Close();
}</code>

다른 방법

데이터세트가 텍스트 파일에 저장되어 있는 경우 이를 DataSet으로 읽고 OpenXML 기능을 사용하여 XML로 변환하는 것을 고려해 보세요. 그런 다음 대량 삽입을 위해 이 XML을 데이터베이스에 전달할 수 있습니다. 그러나 이 접근 방식은 특히 대규모 데이터 세트의 경우 상당한 메모리 리소스를 요구할 수 있습니다.

메모리 고려사항

200만 행의 데이터를 로드하고 삽입하면 시스템 메모리에 부담을 줄 수 있다는 점에 유의하세요. 필요한 경우 메모리 용량이 충분한 서버를 사용하는 것을 고려하거나 데이터 스트리밍 또는 증분 삽입과 같은 다른 솔루션을 살펴보세요.

위 내용은 2백만 개의 행을 SQL Server에 효율적으로 삽입하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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