Before moving to the actual topic that how to call a stored procedure , let's first discuss , what is actually a Stored Procedure.
What is an Stored Procedure
A stored procedure is nothing but a group of T-SQL statements , which can conatin 2 lines of Sql statement to 1000s of sql statements. If an application uses the same query multiple times then we create a stored procedure for the same and later they are called by their name in the application
Advantages of Stored procedure
There are several advantages of using Stored Procedures over adhoc queries (inline SQL)
1.If you will write In-Line SQL queries then maintaining them becomes a challenge also you can't reuse them, but Stored Procedure is created once and could be called several times whenever we need to execute some SQL queries, thus it enhances the reusability, at the same time it decreases the maintenance load, now if we need to change something we could just change the procedure so we just need to change at one place.
2.We also get security with a stored procedure, A database user can be granted access to an SP and could be prevented them from executing direct "select" statements against a table.
3. In-line SQL queries are build by concatenating user inputs which open the doors for SQL injection attack, but Stored procedures prevent SQL injection attack.
4.Stored Procedure is faster than In-Line queries because SQL Server retains the Execution plan for SP, Stored Procedures are compiled and their execution plan is cached and used again when the same SP is executed again
5.With the Stored procedure, we only need to pass the store procedure name from application to SQL server, which reduces the network traffic.
Due to all these advantages, it is very possible that you are asked to create SP and call them from your application.
Store procedure are mainly of three types
1. SP without parameters.
2. SP with input parameters.
3. SP with output parameters.
Let's understand each of them one by one. To understand SP , we will need a database table , so let's create one.
Step1.Open SQL Server Management Studio and Run below script, it will create a database with the name Test and Two tables Employee and Department and populate them with some Test Data.
Step 2.create an Empty webform application.
Step 3 : Include connection string in web.config file
SP without parameters (Display all Employees with their department in a Gridview.)
Step1. Create the procedure.
Step 2. Drag and drop a GridView into the webform.
Step 3.Copy and paste below code into the code behind.
Please notice to call a store procedure we simply specify the name of SP in the constructor of SqlCommand object and Then Specify the command type then as usual to execute the command we use ExecuteReader() method.
step 4. Call this method in page load event so that Grid could load automatically.
SP with input parameters (Add employee details into the database.)
Step 1.create the store procedure.
step 2. Design a form to take user input. copy paste below html.
step 3.Bind department so that Admin can select the department from dropdownlist.
Step 3.Double click on the button control to generate button click event handler and copy paste below code.
Please notice , here we are specifying SP name in the constructor of SqlCommand object and then specifying the command type as store procedure and then providing necessary input parameters using AddWithValue() method .
SP with output parameters (display total count of employee in HR department in a label)
Step 1.Create SP
To create an SP with output parameter, we use the keywords OUT or OUTPUT. @empCount is an OUTPUT parameter. Notice, it is specified with OUT keyword.
Step 2. Call sp from code behind and set label's Text as output Parameter's value.
The complete source code looks like below.