首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Server在SP中执行SP并使用内部SP调用的结果

Server在SP中执行SP并使用内部SP调用的结果
EN

Stack Overflow用户
提问于 2012-08-03 05:20:19
回答 2查看 619关注 0票数 0

我需要在另一个存储过程中执行一个存储过程,并在外部存储过程中使用内部存储过程的结果。

就像下面这样。

SP1

代码语言:javascript
运行
复制
CREATE PROCEDURE spExternal
AS
BEGIN
    SET NOCOUNT ON;

    DECLARE @intInternalResult INT

    SET intInternalResult= EXEC spInternal
END

SP内部

代码语言:javascript
运行
复制
CREATE PROCEDURE spInternal 
AS
BEGIN
    SET NOCOUNT ON;

    SELECT 1+2
END
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-08-03 07:29:04

我的朋友,你不能给你没有返回的变量赋值。您可以编写一个函数来完成存储过程spInternal的工作,这将返回一个值。否则你可以这样做:

代码语言:javascript
运行
复制
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

还有一件事,下次别忘了把@放在变量的前面。

票数 1
EN

Stack Overflow用户

发布于 2012-08-03 08:05:50

如果存储过程仅返回单个整数值,请使用RETURN

代码语言:javascript
运行
复制
create proc pInternal
as
begin
    return 2
end

然后,您可以访问结果如下

代码语言:javascript
运行
复制
exec @intInternalResult = pInternal

如果要返回非整数值或多个值,请使用OUTPUT参数。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11789707

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档