Instance 1: only the stored procedure of a single record set is returned.
The table of bank deposits is as follows:
Requirement 1: query the stored procedure of bankmoney
Create procedure sp_query_bankmoney
As
Select * From bankmoney
Go
Exec sp_query_bankmoney
Note * you only need to replace the SQL statement with the name of the stored procedure during usage, which is convenient!
Instance 2 (passing parameters to the stored procedure ):
Add a record to the bankmoney table and query the total amount of all deposits in the table userid = zhangsan.
Create proc insert_bank @ param1 char (10), @ param2 varchar (20), @ param3 varchar (20), @ param4 int, @ param5 int output
With encryption --------- Encryption
As
Insert bankmoney (ID, userid, sex, money)
Values (@ param1, @ param2, @ param3, @ param4)
Select @ param5 = sum (money) from bankmoney where userid = 'hangsan'
Go
You can run this stored procedure in the SQL Server Query analyzer:
Declare @ total_price int
Exec insert_bank '004 ', 'hangsan', 'mal', 100, @ total_price output
Print 'total balance is '+ convert (varchar, @ total_price)
Go
Here, I will refer to the three types of return values of the stored procedure (so that the users who are reading this example do not have to check the syntax ):
1. Return an integer with return
2. Return parameters in output format
3. recordset
Differences between return values:
Both output and return can be received using variables in a batch program, while recordset is passed back to the client that executes the batch.
Example 3: simple process with complex select statements
The following stored procedure returns all authors (names provided), published books, and publishers from the join of the four tables. This stored procedure does not use any parameters.
Use pubs
If exists (Select name from sysobjects
Where name = 'au _ info_all 'and type = 'P ')
Drop procedure au_info_all
Go
Create procedure au_info_all
As
Select au_lname, au_fname, title, pub_name
From authors a inner join titleauthor Ta
On a. au_id = TA. au_id inner join titles t
On T. title_id = TA. title_id inner join publishers P
On T. pub_id = P. pub_id
Go
The au_info_all stored procedure can be executed in the following ways:
Execute au_info_all
-- Or
Exec au_info_all
If the process is the first statement in batch processing, you can use:
Au_info_all
Example 4: simple process with Parameters
Create procedure au_info
@ Lastname varchar (40 ),
@ Firstname varchar (20)
As
Select au_lname, au_fname, title, pub_name
From authors a inner join titleauthor Ta
On a. au_id = TA. au_id inner join titles t
On T. title_id = TA. title_id inner join publishers P
On T. pub_id = P. pub_id
Where au_fname = @ firstname
And au_lname = @ lastname
Go
The au_info stored procedure can be executed in the following ways:
Execute au_info 'dull ', 'ann'
-- Or
Execute au_info @ lastname = 'dull ', @ firstname = 'ann'
-- Or
Execute au_info @ firstname = 'ann ', @ lastname = 'dull'
-- Or
Exec au_info 'dull ', 'ann'
-- Or
Exec au_info @ lastname = 'dull ', @ firstname = 'ann'
-- Or
Exec au_info @ firstname = 'ann ', @ lastname = 'dull'
If the process is the first statement in batch processing, you can use:
Au_info 'dull', 'ann'
-- Or
Au_info @ lastname = 'dull ', @ firstname = 'ann'
-- Or
Au_info @ firstname = 'ann ', @ lastname = 'dull'
Example 5: simple process with wildcard Parameters
Create procedure au_info2
@ Lastname varchar (30) = 'd % ',
@ Firstname varchar (18) = '%'
As
Select au_lname, au_fname, title, pub_name
From authors a inner join titleauthor Ta
On a. au_id = TA. au_id inner join titles t
On T. title_id = TA. title_id inner join publishers P
On T. pub_id = P. pub_id
Where au_fname like @ firstname
And au_lname like @ lastname
Go
The au_info2 stored procedure can be executed in multiple combinations. Only some combinations are listed below:
Execute au_info2
-- Or
Execute au_info2 'wh %'
-- Or
Execute au_info2 @ firstname = 'a %'
-- Or
Execute au_info2 '[Ck] ARS [OE] N'
-- Or
Execute au_info2 'hunter', 'sheryl'
-- Or
Execute au_info2 'H % ','s %'
= 'Proc2'