当前位置:  开发笔记 > 编程语言 > 正文

将SP返回值设置为SQL Server中的变量

如何解决《将SP返回值设置为SQLServer中的变量》经验,为你挑选了3个好方法。

我有一个sproc返回一行和一个文本列,我需要将此文本设置为一个变量,如:

declare @bla varchar(100)
select @bla = sp_Name 9999, 99989999, 'A', 'S', null

但当然,这段代码不起作用......

谢谢!



1> Tim C..:

如果您无法更改存储过程,则另一种解决方案是定义临时表,并将结果插入其中

DECLARE @Output VARCHAR(100)

CREATE TABLE #tmpTable
(
    OutputValue VARCHAR(100)
)
INSERT INTO #tmpTable (OutputValue)
EXEC dbo.sp_name 9999, 99989999, 'A', 'S', null

SELECT
    @Output = OutputValue
FROM 
    #tmpTable

DROP TABLE #tmpTable



2> Tim C..:

如果存储过程返回单个值,您可以将存储过程中的一个参数定义为OUTPUT变量,然后存储过程将设置参数的值

CREATE PROCEDURE dbo.sp_Name
    @In INT,
    @Out VARCHAR(100) OUTPUT

AS
BEGIN
    SELECT @Out = 'Test'
END
GO

然后,您将获得如下输出值

DECLARE @OUT VARCHAR(100)
EXEC sp_name 1, @Out OUTPUT
PRINT @Out



3> DiGi..:
DECLARE
  @out INT

EXEC @out = sp_name 'param', 2, ...

T-SQL"EXECUTE" 帮助中的更多信息(帮助来自MSSQL 2008,但这也适用于2000)

推荐阅读
coco2冰冰
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有