>백엔드 개발 >C++ >C#에서 매개변수화된 데이터를 데이터베이스에 효율적으로 대량 삽입하려면 어떻게 해야 합니까?

C#에서 매개변수화된 데이터를 데이터베이스에 효율적으로 대량 삽입하려면 어떻게 해야 합니까?

Patricia Arquette
Patricia Arquette원래의
2025-01-03 21:18:091033검색

How Can C# Efficiently Bulk Insert Parameterized Data into a Database?

C#을 사용하여 매개변수화된 변수를 데이터베이스에 대량 삽입

수많은 매개변수화된 변수를 데이터베이스에 효율적으로 삽입하는 것은 개발자가 직면하는 일반적인 과제입니다. C#은 테이블 반환 매개 변수와 저장 프로시저를 사용하여 단일 쿼리에 여러 행을 삽입하는 솔루션을 제공합니다.

사용자 정의 테이블 유형 만들기

대상 데이터베이스의 구조를 미러링하는 사용자 정의 테이블 유형 table:

CREATE TYPE MyTableType AS TABLE
(
    Col1 int,
    Col2 varchar(20) 
)
GO

저장 프로시저 정의

다음으로 새로 생성된 테이블 유형을 입력 매개 변수로 받아들이는 저장 프로시저를 만듭니다.

CREATE PROCEDURE MyProcedure
(
    @MyTable dbo.MyTableType READONLY -- NOTE: table valued parameters must be Readonly!
)
AS

INSERT INTO MyTable (Col1, Col2)
SELECT Col1, Col2 
FROM @MyTable

GO

이 저장 프로시저는 @MyTable 테이블 유형의 데이터를 MyTable 테이블에 삽입합니다. 데이터베이스.

C#에서 저장 프로시저 실행

마지막으로 다음 코드를 사용하여 C#에서 저장 프로시저를 실행합니다.

DataTable dt = new DataTable();
dt.Columns.Add("Col1", typeof(int));
dt.Columns.Add("Col2", typeof(string));

// Fill your data table here

using (var con = new SqlConnection("ConnectionString"))
{
    using(var cmd = new SqlCommand("MyProcedure", con))
    {
        cmd.CommandType = CommandType.StoredProcedure;
        cmd.Parameters.Add("@MyTable", SqlDbType.Structured).Value = dt;
        con.Open();
        cmd.ExecuteNonQuery();
    }
}

테이블 값 사용의 장점 매개변수

테이블 반환 매개변수를 사용하면 여러 가지 이점이 있습니다.

  • 효율성: 단일 쿼리가 여러 삽입 문을 대체하여 성능이 크게 향상됩니다.
  • 매개변수화됨: 데이터가 매개변수화 방식으로 전달되므로 위험이 줄어듭니다.
  • 확장 가능: 저장 프로시저를 변경하지 않고도 다양한 시나리오에 맞게 사용자 정의 테이블 유형을 수정할 수 있습니다.

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

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