本指南示範如何將字串清單作為參數從 C# 應用程式傳遞給 SQL Server 預存程序。 此方法使用使用者定義的表格類型(UDTT),適用於 SQL Server 2008 及更高版本。
首先,在 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# 程式碼中使用 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 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中文網其他相關文章!