>백엔드 개발 >C++ >C#에서 매개 변수가 있는 쿼리를 사용하여 데이터를 효율적으로 대량 삽입하려면 어떻게 해야 합니까?

C#에서 매개 변수가 있는 쿼리를 사용하여 데이터를 효율적으로 대량 삽입하려면 어떻게 해야 합니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-03 21:58:39580검색

How Can I Efficiently Bulk Insert Data with Parameterized Queries in C#?

C에서 데이터베이스에 매개 변수가 있는 변수 대량 삽입

C#에서는 각 행에 별도의 INSERT가 필요한 경우 데이터베이스에 여러 행을 삽입하는 데 시간이 많이 걸릴 수 있습니다. 성명. 성능을 최적화하려면 단일 쿼리에 여러 행을 삽입하는 동시에 매개변수화된 쿼리를 활용하여 SQL 주입 공격을 방지하는 것이 바람직합니다.

이를 달성하려면 테이블 반환 매개변수의 강력한 기능을 활용하여 다음을 수행할 수 있습니다. 구조화된 데이터 유형(예: DataTable)을 저장 프로시저에 전달합니다. 이를 통해 단일 명령으로 여러 행을 삽입할 수 있습니다.

이 접근 방식을 구현하려면 다음 단계를 따르세요.

1. 사용자 정의 테이블 유형(UDT) 생성

삽입하려는 행을 나타내는 UDT를 생성합니다. 예를 들어 "Col1" 및 "Col2" 열이 있는 경우 다음과 같이 UDT를 생성할 수 있습니다.

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

2. 저장 프로시저 생성

UDT를 매개변수로 받아들이는 저장 프로시저 생성:

CREATE PROCEDURE MyProcedure
(
    @MyTable dbo.MyTableType READONLY -- Table valued parameters must be ReadOnly!
)
AS

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

GO

3. C에서 저장 프로시저 실행

데이터로 DataTable 채우기:

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

// Populate data

연결을 열고 SqlCommand를 사용하여 저장 프로시저 실행:

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();
    }
}

By 테이블 반환 매개 변수와 저장 프로시저를 활용하면 대량 삽입의 성능을 크게 향상시키는 동시에 매개 변수화된 삽입의 보안과 효율성을 유지할 수 있습니다. 쿼리합니다.

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

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