Thay vì:
SET @S=EXEC spGetNthNo @a,@d,@n
Bạn cần:
EXEC @S = spGetNthNo @a,@d,@n
Và sau đó trong thủ tục, bạn cần một cái gì đó như:
RETURN 100
hoặc:
RETURN @x
cho giá trị bạn muốn cho @S sau khi thủ tục thực thi.
Bạn cũng có thể sử dụng các tham số đầu ra. Ví dụ kết hợp:
IF OBJECT_ID('tempdb..#example') IS NOT NULL DROP PROCEDURE #example
GO
CREATE PROCEDURE #example
@output_param INT OUTPUT
AS BEGIN
SET @output_param = 100
RETURN 200
END
GO
DECLARE @return INT, @param INT
EXEC @return = #example @output_param = @param OUTPUT
SELECT @return as [return value], @param as [output parameter]