首頁 > 資料庫 > mysql教程 > 如何在 C# 中將字串清單傳遞給 SQL Server 預存程序?

如何在 C# 中將字串清單傳遞給 SQL Server 預存程序?

Susan Sarandon
發布: 2025-01-13 10:21:43
原創
231 人瀏覽過

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

從 C# 將字串清單傳遞到 SQL Server 預存程序

本指南示範如何將字串清單作為參數從 C# 應用程式傳遞給 SQL Server 預存程序。 此方法使用使用者定義的表格類型(UDTT),適用於 SQL Server 2008 及更高版本。

定義使用者定義表格類型(UDTT)

首先,在 SQL Server 中建立一個 UDTT 來表示您的字串清單:

<code class="language-sql">CREATE TYPE [dbo].[StringList] AS TABLE(
    [Item] [NVARCHAR](MAX) NULL
);</code>
登入後複製

修改預存程序

接下來,修改您的預存程序以接受 UDTT 作為輸入:

<code class="language-sql">CREATE PROCEDURE [dbo].[sp_UseStringList]
    @list StringList READONLY
AS
BEGIN
    -- Process the string list
    SELECT l.Item FROM @list l;
END</code>
登入後複製

C# 實作

以下是如何在 C# 程式碼中使用 UDTT:

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

    using (SqlCommand cmd = new SqlCommand("sp_UseStringList", con))
    {
        cmd.CommandType = CommandType.StoredProcedure;
        cmd.Parameters.AddWithValue("@list", CreateStringListTable(new List<string> { "Apple", "Banana", "Orange" }));

        using (SqlDataReader reader = cmd.ExecuteReader())
        {
            while (reader.Read())
            {
                // Process each string from the reader
                string item = reader["Item"].ToString();
                Console.WriteLine(item);
            }
        }
    }
}


//Helper function to create the DataTable
private DataTable CreateStringListTable(List<string> stringList)
{
    DataTable dt = new DataTable();
    dt.Columns.Add("Item", typeof(string));
    foreach (string str in stringList)
    {
        dt.Rows.Add(str);
    }
    return dt;
}</code>
登入後複製

執行預存程序(SQL 範例)

出於測試目的,您可以直接在 SQL Server Management Studio (SSMS) 中執行預存程序,如下所示:

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

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

EXEC sp_UseStringList @list;</code>
登入後複製

當從 C# 應用程式與 SQL Server 預存程序互動時,此方法提供了一種強大而有效的方法來處理字串清單。 與其他方法相比,使用 UDTT 可確保資料完整性並提高效能。

以上是如何在 C# 中將字串清單傳遞給 SQL Server 預存程序?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板