SQL Server:在变量中捕获动态 SQL 查询结果
存储过程通常使用动态 SQL,动态构建查询。 关键的挑战是在过程本身中检索这些动态查询的结果。
考虑这个场景:
<code class="language-sql">DECLARE @sqlCommand nvarchar(1000) DECLARE @city varchar(75) SET @city = 'London' SET @sqlCommand = 'SELECT COUNT(*) FROM customers WHERE City = @city' EXECUTE sp_executesql @sqlCommand, N'@city nvarchar(75)', @city = @city</code>
此代码片段动态生成 COUNT(*)
查询,但不捕获结果。 为了解决这个问题,我们需要一种修改方法:
<code class="language-sql">DECLARE @sqlCommand NVARCHAR(1000) DECLARE @count INT DECLARE @city VARCHAR(75) SET @city = 'New York' SET @sqlCommand = 'SELECT @cnt=COUNT(*) FROM customers WHERE City = @city' EXECUTE sp_executesql @sqlCommand, N'@city nvarchar(75), @cnt int OUTPUT', @city = @city, @cnt = @count OUTPUT SELECT @count</code>
详细解释如下:
声明结果变量:我们将 @cnt
声明为 INT
来保存查询的输出。
修改动态 SQL: 调整 SELECT
语句,将 COUNT(*)
结果分配给 @cnt
:SELECT @cnt=COUNT(*)
.
将 sp_executesql
与 OUTPUT 一起使用: sp_executesql
与 OUTPUT
参数一起使用,以指定 @cnt
将接收来自查询的值。 注意参数声明@cnt int OUTPUT
.
检索结果:执行后,@cnt
包含计数。 SELECT @count
显示存储的值。
这种改进的方法可以有效地将动态 SQL 结果捕获到变量中,从而能够在存储过程中进行进一步处理或返回。
以上是如何将动态 SQL 查询结果捕获到 SQL Server 中的变量中?的详细内容。更多信息请关注PHP中文网其他相关文章!