Pra*_*bhu 97 sql t-sql sql-server stored-procedures
如何在SQL中为变量分配exec调用的结果?我有一个名为的存储过程up_GetBusinessDay,它返回一个日期.
你能做这样的事吗:
exec @PreviousBusinessDay = dbo.up_GetBusinessDay @Date, -1
Run Code Online (Sandbox Code Playgroud)
KM.*_*KM. 86
我总是使用返回值来传递错误状态.如果你需要传回一个值,我会使用输出参数.
示例存储过程,带有OUTPUT参数:
CREATE PROCEDURE YourStoredProcedure
(
@Param1 int
,@Param2 varchar(5)
,@Param3 datetime OUTPUT
)
AS
IF ISNULL(@Param1,0)>5
BEGIN
SET @Param3=GETDATE()
END
ELSE
BEGIN
SET @Param3='1/1/2010'
END
RETURN 0
GO
Run Code Online (Sandbox Code Playgroud)
使用OUTPUT参数调用存储过程:
DECLARE @OutputParameter datetime
,@ReturnValue int
EXEC @ReturnValue=YourStoredProcedure 1,null, @OutputParameter OUTPUT
PRINT @ReturnValue
PRINT CONVERT(char(23),@OutputParameter ,121)
Run Code Online (Sandbox Code Playgroud)
OUTPUT:
0
2010-01-01 00:00:00.000
Run Code Online (Sandbox Code Playgroud)
小智 51
如果您只想返回一个整数,这将有效:
DECLARE @ResultForPos INT
EXEC @ResultForPos = storedprocedureName 'InputParameter'
SELECT @ResultForPos
Run Code Online (Sandbox Code Playgroud)
AZ *_*had 28
declare @EventId int
CREATE TABLE #EventId (EventId int)
insert into #EventId exec rptInputEventId
set @EventId = (select * from #EventId)
drop table #EventId
Run Code Online (Sandbox Code Playgroud)
从文档(假设您使用SQL-Server):
USE AdventureWorks;
GO
DECLARE @returnstatus nvarchar(15);
SET @returnstatus = NULL;
EXEC @returnstatus = dbo.ufnGetSalesOrderStatusText @Status = 2;
PRINT @returnstatus;
GO
Run Code Online (Sandbox Code Playgroud)
所以是的,它应该以这种方式工作.
| 归档时间: |
|
| 查看次数: |
273556 次 |
| 最近记录: |