Returning a Computed Value as a Stored Procedure Output Parameter : Procedure with Parameters « Sequence « SQL Server / T-SQL






Returning a Computed Value as a Stored Procedure Output Parameter


1> create table employee(
2>     ID          int,
3>     name        nvarchar (10),
4>     salary      int,
5>     start_date  datetime,
6>     city        nvarchar (10),
7>     region      char (1))
8> GO
1>
2> insert into employee (ID, name,    salary, start_date, city,       region)
3>               values (1,  'Jason', 40420,  '02/01/94', 'New York', 'W')
4> GO

(1 rows affected)
1> insert into employee (ID, name,    salary, start_date, city,       region)
2>               values (2,  'Robert',14420,  '01/02/95', 'Vancouver','N')
3> GO

(1 rows affected)
1> insert into employee (ID, name,    salary, start_date, city,       region)
2>               values (3,  'Celia', 24020,  '12/03/96', 'Toronto',  'W')
3> GO

(1 rows affected)
1> insert into employee (ID, name,    salary, start_date, city,       region)
2>               values (4,  'Linda', 40620,  '11/04/97', 'New York', 'N')
3> GO

(1 rows affected)
1> insert into employee (ID, name,    salary, start_date, city,       region)
2>               values (5,  'David', 80026,  '10/05/98', 'Vancouver','W')
3> GO

(1 rows affected)
1> insert into employee (ID, name,    salary, start_date, city,       region)
2>               values (6,  'James', 70060,  '09/06/99', 'Toronto',  'N')
3> GO

(1 rows affected)
1> insert into employee (ID, name,    salary, start_date, city,       region)
2>               values (7,  'Alison',90620,  '08/07/00', 'New York', 'W')
3> GO

(1 rows affected)
1> insert into employee (ID, name,    salary, start_date, city,       region)
2>               values (8,  'Chris', 26020,  '07/08/01', 'Vancouver','N')
3> GO

(1 rows affected)
1> insert into employee (ID, name,    salary, start_date, city,       region)
2>               values (9,  'Mary',  60020,  '06/09/02', 'Toronto',  'W')
3> GO

(1 rows affected)
1>
2> select * from employee
3> GO
ID          name       salary      start_date              city       region
----------- ---------- ----------- ----------------------- ---------- ------
          1 Jason            40420 1994-02-01 00:00:00.000 New York   W
          2 Robert           14420 1995-01-02 00:00:00.000 Vancouver  N
          3 Celia            24020 1996-12-03 00:00:00.000 Toronto    W
          4 Linda            40620 1997-11-04 00:00:00.000 New York   N
          5 David            80026 1998-10-05 00:00:00.000 Vancouver  W
          6 James            70060 1999-09-06 00:00:00.000 Toronto    N
          7 Alison           90620 2000-08-07 00:00:00.000 New York   W
          8 Chris            26020 2001-07-08 00:00:00.000 Vancouver  N
          9 Mary             60020 2002-06-09 00:00:00.000 Toronto    W

(9 rows affected)
1>
2> --Returning a Computed Value as a Stored Procedure Output Parameter
3>
4> CREATE PROCEDURE usp_MedianSubTotal
5> @MedianVal money OUTPUT
6> AS
7> DECLARE @rnval int
8> --Compute near middle row
9> SET @rnval = (SELECT COUNT(*) FROM Employee)
10> SET @MedianVal = (SELECT sum(Salary) FROM Employee )/@rnval
11> GO
1>
2>
3> DECLARE @MedValue money
4>
5> EXEC usp_MedianSubTotal @MedianVal = @MedValue OUTPUT
6>
7> SELECT @MedValue 'Median value'
8> GO
Median value
---------------------
           49580.0000

(1 rows affected)
1>
2> drop table employee
3> GO
1>
           
       








Related examples in the same category

1.Parameterization: Make use of a few input parameters to create a new record
2.Supplying Default Values
3.Procedure with two parameters
4.Pass a constant to a function
5.Using a Parameter in a WHERE Clause in a procedure
6.If you had two parameters, you could designate them
7.Stored procedure: accepts a ID, name and city and inserts them as new row
8.Procedure Based on input value
9.Pass in three parameters
10.Create procedure with OUTPUT Parameters
11.Pass variable to procedure output parameters
12.Using output parameter to return Values