>데이터 베이스 >MySQL 튜토리얼 >C#에서 SQL Server 저장 프로시저로 문자열 목록을 효율적으로 전달하는 방법은 무엇입니까?

C#에서 SQL Server 저장 프로시저로 문자열 목록을 효율적으로 전달하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-13 10:50:42330검색

How to Efficiently Pass a List of Strings from C# to a SQL Server Stored Procedure?

C# 및 SQL Server: 저장 프로시저에서 문자열 목록을 효율적으로 처리

C#에서 SQL Server 저장 프로시저와 상호 작용할 때 흔히 발생하는 문제는 문자열 값의 동적 목록을 전달하는 것입니다. 이 문서에서는 UDTT(사용자 정의 테이블 유형)를 사용하는 강력한 솔루션을 보여줍니다.

문제: 동적 문자열 목록

가변 길이 문자열 목록을 기반으로 결과를 필터링해야 하는 저장 프로시저를 상상해 보세요. 이 목록을 직접 전달하는 것은 문제가 될 수 있습니다.

솔루션: 사용자 정의 테이블 유형(UDTT)

SQL Server 2008 이상 버전에서는 UDTT를 우아한 솔루션으로 제공합니다. 문자열 컬렉션을 캡슐화하기 위해 StringList이라는 UDTT를 생성하겠습니다.

저장 프로시저 생성

이 저장 프로시저는 StringList 유형을 사용합니다.

<code class="language-sql">CREATE PROCEDURE [dbo].[sp_UseStringList]
    @list StringList READONLY
AS
BEGIN
    -- Retrieve and return items from the input list
    SELECT l.Item FROM @list l;
END</code>

C# 구현

아래 C# 코드는 이 저장 프로시저를 활용하는 방법을 보여줍니다.

<code class="language-csharp">using (var con = new SqlConnection(connstring))
{
    con.Open();

    using (SqlCommand cmd = new SqlCommand("exec sp_UseStringList @list", con))
    {
        // Create a DataTable to hold the string list
        using (var table = new DataTable())
        {
            table.Columns.Add("Item", typeof(string));

            // Add sample data – replace with your actual list
            for (int i = 0; i < 10; i++)
            {
                table.Rows.Add("String" + i);
            }

            // Add the DataTable as a parameter to the command.
            SqlParameter tvpParam = cmd.Parameters.AddWithValue("@list", table);
            tvpParam.SqlDbType = SqlDbType.Structured;
            tvpParam.TypeName = "dbo.StringList";

            // Execute the command.
            using (SqlDataReader reader = cmd.ExecuteReader())
            {
                // Process the results
                while (reader.Read())
                {
                    Console.WriteLine(reader["Item"].ToString());
                }
            }
        }
    }
}</code>

SSMS 실행 예시

SSMS(SQL Server Management Studio)에서 테스트하는 경우:

<code class="language-sql">DECLARE @list AS StringList;

INSERT INTO @list VALUES ('Apple'), ('Banana'), ('Orange');

EXEC sp_UseStringList @list;</code>

이 접근 방식은 구조화된 데이터 전송을 위해 UDTT의 강력한 기능을 활용하여 C#에서 SQL Server 저장 프로시저로 문자열 목록을 전달하는 깔끔하고 효율적인 방법을 제공합니다. "dbo.StringList"을 변경한 경우 올바른 스키마와 이름으로 바꿔야 합니다.

위 내용은 C#에서 SQL Server 저장 프로시저로 문자열 목록을 효율적으로 전달하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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