在存储过程中初始化输出参数

时间:2012-11-14 09:12:49

标签: sql-server stored-procedures

我有一个带有输出参数的存储过程,我用“0”初始化:

ALTER PROCEDURE dbo.SomeProcedure
    @someparam INT = 0 OUT
...

但是,当程序在执行期间没有修改或设置该参数时,输出值为NULL,而不是预期的“0”。

是否必须在过程代码中设置默认值

SET @someparam = 0; 

并避免声明中的初始化?

为什么SQL Server允许在声明输出参数时使用默认值?

1 个答案:

答案 0 :(得分:9)

您显示的语法不适用于初始化,适用于default values for missing parameters

  

default参数的默认值。如果定义了默认值   对于参数,可以在不指定a的情况下执行过程   该参数的值

那么应该很清楚,如果你能读取输出值,那么你必须为@someparam提供一个参数,因此它不会“丢失”。如果没有“丢失”,则不会为其分配默认值,因为它必须已经有一个值,即来自调用者帧的值(可能为NULL)。 QED。

以下代码显示了差异,并举例说明了您看到的行为:

create procedure usp_test
    @p int = 0 output
as
    set @p += 1;
    select @p;
go

exec usp_test;
go


declare @unitialized int;
exec usp_test @unitialized output;
go