使用T-SQL 在動態SQL 語句中傳遞參數
在T-SQL 中,動態SQL 提供了一種建構與執行SQL 語句的方法以程式設計方式。在動態 SQL 中使用參數時,了解正確的語法非常重要。
考慮以下範例:
CREATE PROCEDURE [dbo].[sp_Test1] /* 'b0da56dc-fc73-4c0e-85f7-541e3e8f249d' */ ( @p_CreatedBy UNIQUEIDENTIFIER ) AS DECLARE @sql NVARCHAR(4000) SET @sql =' DECLARE @p_CreatedBY UNIQUEIDENTIFIER SELECT DateTime, Subject, CreatedBy FROM ( SELECT DateTime, Subject, CreatedBy, ROW_NUMBER() OVER(ORDER BY DateTime ) AS Indexing FROM ComposeMail WHERE CreatedBy = @p_CreatedBy /* <--- the problem is in this condition */ ) AS NewDataTable ' EXEC sp_executesql @sql
在不使用 WHERE 子句的情況下執行此程序時,它可以正常工作。但是,當新增帶有 UNIQUEIDENTIFIER 參數的 WHERE 子句時,不會傳回任何結果。問題在於動態SQL語句中參數的使用不正確。
要解決此問題,必須將參數傳遞給sp_executesql語句。根據 MSDN:
... WHERE CreatedBy = @p ... EXECUTE sp_executesql @sql, N'@p UNIQUEIDENTIFIER', @p = @p_CreatedBY
在此修改後的程式碼中,參數 @p 在 WHERE 子句中使用,並呼叫 sp_executesql 語句,並將 @p 參數設為 @p_CreatedBY 的值。這可確保 UNIQUEIDENTIFIER 參數正確傳遞給動態 SQL 語句。
以上是如何在T-SQL動態SQL語句中正確傳遞參數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!