Wie weist man das Ergebnis eines exec-Aufrufs einer Variablen in SQL zu? Ich habe einen gespeicherten Prozess namens "up_GetBusinessDay", der ein einzelnes Datum zurückgibt.
Können Sie so etwas tun:
exec @PreviousBusinessDay = dbo.up_GetBusinessDay @Date, -1
Ich verwende immer den Rückgabewert, um den Fehlerstatus zurückzugeben. Wenn Sie einen Wert zurückgeben müssen, würde ich einen Ausgabeparameter verwenden.
Beispiel einer gespeicherten Prozedur mit einem OUTPUT-Parameter:
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
Aufruf der gespeicherten Prozedur, mit einem OUTPUT-Parameter:
DECLARE @OutputParameter datetime
,@ReturnValue int
EXEC @ReturnValue=YourStoredProcedure 1,null, @OutputParameter OUTPUT
PRINT @ReturnValue
PRINT CONVERT(char(23),@OutputParameter ,121)
OUTPUT:
0
2010-01-01 00:00:00.000
Dies funktioniert, wenn Sie einfach eine ganze Zahl zurückgeben möchten:
DECLARE @ResultForPos INT
EXEC @ResultForPos = storedprocedureName 'InputParameter'
SELECT @ResultForPos
Aus der Dokumentation (unter der Annahme, dass Sie SQL-Server verwenden):
USE AdventureWorks;
GO
DECLARE @returnstatus nvarchar(15);
SET @returnstatus = NULL;
EXEC @returnstatus = dbo.ufnGetSalesOrderStatusText @Status = 2;
PRINT @returnstatus;
GO
Also ja, so sollte es funktionieren.