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