首頁 >資料庫 >mysql教程 >如何在T-SQL動態SQL語句中正確傳遞參數?

如何在T-SQL動態SQL語句中正確傳遞參數?

DDD
DDD原創
2025-01-05 03:02:39753瀏覽

How to Correctly Pass Parameters in T-SQL Dynamic SQL Statements?

使用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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn