Stored Procedures: Output Parameters

Learn about the output parameters in stored procedures.

We'll cover the following

Stored procedures, unlike functions, do not have to return any data back to the caller. They only execute the code that they encompass. Nevertheless, it is possible to return a result back from stored procedures. We can mark a parameter of a stored procedure with the OUTPUT keyword so that the value of the parameter can be used in the context where the stored procedure is called. In other words, using output parameters is one of the ways of returning data from stored procedures.

Syntax

Output parameters are declared in the same place where we have input parameters. The only difference is that they are marked with the OUTPUT keyword:

CREATE PROCEDURE Schema.ProcedureName
    @Parameter1 NVARCHAR(100),
    @Parameter2 INT OUTPUT
AS
BEGIN
    [Procedure body]
END;

In the code snippet above, @Parameter2 is an output parameter of type INT. To return a result, we simply assign this output parameter a value:

CREATE PROCEDURE Schema.ProcedureName
    @Parameter1 NVARCHAR(100),
    @Parameter2 INT OUTPUT
AS
BEGIN
    [Procedure body]
    SET @Parameter2 = 12
END;

Usage

To execute a stored procedure that requires an output parameter, we have to first create a variable of the same type as the output parameter and pass it along with the OUTPUT keyword:

DECLARE @VariableToHoldTheResult AS INT

EXEC Schema.ProcedureName 'Parameter1', @VariableToHoldTheResult OUTPUT

-- We can now use @VariableToHoldTheResult to view the result of the stored procedure

When we pass an output parameter, we are basically providing the stored procedure a place where it can store the result.

Example

Let’s say we have a table called Products:

CREATE TABLE dbo.Products
(
    Id INT PRIMARY KEY IDENTITY(1, 1),
    Name NVARCHAR(100) NOT NULL,
    Price INT NOT NULL,
    QuantityLeft INT NOT NULL
);

We want to create a stored procedure that will calculate the total price of inventory that we have in our warehouse. To do that, we multiply Price by QuantityLeft for each product in our table. We must also return this result through an output parameter.

First, let’s create the base structure of our procedure:

CREATE PROCEDURE dbo.CalculateInventoryPrice
    @TotalPrice INT OUTPUT
AS
BEGIN
    [Procedure body]
END

The procedure will write the result to @TotalPrice. All we have to do now is to calculate the total price of inventory and assign this result to the output parameter:

Get hands-on with 1300+ tech skills courses.