我需要在另一个存储过程中执行一个存储过程,并在外部存储过程中使用内部存储过程的结果。
就像下面这样。
SP1
CREATE PROCEDURE spExternal
AS
BEGIN
SET NOCOUNT ON;
DECLARE @intInternalResult INT
SET intInternalResult= EXEC spInternal
END
SP内部
CREATE PROCEDURE spInternal
AS
BEGIN
SET NOCOUNT ON;
SELECT 1+2
END
发布于 2012-08-03 07:29:04
我的朋友,你不能给你没有返回的变量赋值。您可以编写一个函数来完成存储过程spInternal的工作,这将返回一个值。否则你可以这样做:
CREATE PROCEDURE spInternal
AS
BEGIN
SELECT 1+2
END
CREATE PROCEDURE spExternal
AS
BEGIN
DECLARE @intInternalResult INT
CREATE TABLE #temp
(
Rslt int
)
INSERT INTO #temp (Rslt)
EXEC spInternal
SELECT @intInternalResult = Rslt
FROM #temp
DROP TABLE #temp
PRINT @intInternalResult
END
EXEC spExternal
还有一件事,下次别忘了把@放在变量的前面。
发布于 2012-08-03 08:05:50
如果存储过程仅返回单个整数值,请使用RETURN
create proc pInternal
as
begin
return 2
end
然后,您可以访问结果如下
exec @intInternalResult = pInternal
如果要返回非整数值或多个值,请使用OUTPUT
参数。
https://stackoverflow.com/questions/11789707
复制相似问题