首页 > 数据库 > mysql教程 > 如何在T-SQL动态SQL语句中正确传递参数?

如何在T-SQL动态SQL语句中正确传递参数?

DDD
发布: 2025-01-05 03:02:39
原创
707 人浏览过

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

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板