Bagaimana anda menetapkan hasil dari exec panggilan untuk sebuah variabel dalam SQL? Aku punya disimpan proc disebut up_GetBusinessDay
, yang mengembalikan satu tanggal.
Anda dapat melakukan sesuatu seperti ini:
exec @PreviousBusinessDay = dbo.up_GetBusinessDay @Date, -1
Saya selalu menggunakan kembali nilai untuk lulus kembali status kesalahan. Jika anda perlu untuk lulus kembali satu nilai I'd gunakan parameter output.
sampel disimpan prosedur, dengan 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
panggilan untuk prosedur yang tersimpan, dengan 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
Ini akan bekerja jika anda hanya ingin mengembalikan integer:
DECLARE @ResultForPos INT
EXEC @ResultForPos = storedprocedureName 'InputParameter'
SELECT @ResultForPos
Dari dokumentasi (dengan asumsi bahwa anda menggunakan SQL Server):
USE AdventureWorks;
GO
DECLARE @returnstatus nvarchar(15);
SET @returnstatus = NULL;
EXEC @returnstatus = dbo.ufnGetSalesOrderStatusText @Status = 2;
PRINT @returnstatus;
GO
Jadi ya, harus bekerja dengan cara itu.
Saya memiliki pertanyaan yang sama. Sementara ada jawaban yang baik di sini, saya memutuskan untuk membuat table-valued function. Dengan meja (atau skalar) nilai fungsi yang anda don't harus mengubah anda disimpan proc. Saya hanya melakukan select dari table-valued function. Perhatikan bahwa parameter (MyParameter adalah opsional).
MEMBUAT FUNGSI [dbo].[MyDateFunction] (@MyParameter varchar(max)) MENGEMBALIKAN TABEL SEBAGAI KEMBALI ( --- Query tabel atau view atau apapun dan pilih hasil. PILIH DateValue DARI MyTable WHERE ID = @MyParameter; )
Untuk menetapkan variabel anda anda hanya dapat melakukan sesuatu seperti:
Menyatakan @MyDate datetime; SET @MyDate = (PILIH DateValue DARI MyDateFunction(@MyParameter));
Anda juga dapat menggunakan fungsi bernilai skalar:
MEMBUAT FUNGSI TestDateFunction() KEMBALI datetime BEGIN KEMBALI (SELECT GetDate()); END
Kemudian anda hanya dapat melakukan
Menyatakan @MyDate datetime; SET @MyDate = (Pilih dbo.TestDateFunction()); PILIH @MyDate;