Creating and Using MySQL Stored Procedures - A Tutorial
Traducciones al EspañolEstamos traduciendo nuestros guías y tutoriales al Español. Es posible que usted esté viendo una traducción generada automáticamente. Estamos trabajando con traductores profesionales para verificar las traducciones de nuestro sitio web. Este proyecto es un trabajo en curso.
Stored procedures are user-defined SQL statements that are stored in a MySQL database and executed on-demand to perform a specific database operation. These predefined subroutines help in moving the business logic to the database, which offers a few benefits:
- Round trips made to the database server by an application are minimized.
- Code maintainability is enhanced, since different applications can share the stored procedure.
- Database performance is improved, because stored procedures are compiled once and executed very quickly and efficiently.
In this guide, you will:
Learn the syntax for creating stored procedures, and declare your first procedure.
Execute the example procedure after you’ve declared it.
Learn how to delete a procedure when you no longer need it.
Before You Begin
Make sure you have the following:
A configured Linode server. You can learn how to create and setup a Linode server by reading our Getting Started with Linode guide.
A MySQL server and client installed on the Linode server. Installation guides for MySQL are available for different distributions in our MySQL section.
Prepare the Database
You will start by creating a sample database, table, and user for accessing the database. You will also populate the table with sample data for testing purposes.
Creating the Database, Table, and User
Log into the MySQL server:
mysql -u root -p
You will be prompted to enter the root password of your MySQL database. Then, hit Enter to continue.
Next, you will see a MySQL prompt similar to the one shown below.
mysql >
Enter the command below to create a
test_db
database:CREATE DATABASE test_db;
Output:
Query OK, 1 row affected (0.01 sec)
Create a database user and grant full access to the
test_db
database. ReplacePASSWORD
with a complex and unique value that follows the guidelines for MySQL passwords:CREATE USER 'test_user'@'localhost' IDENTIFIED BY 'PASSWORD';
Output:
Query OK, 1 row affected (0.01 sec)
Grant the
test_user
full privileges to thetest_db
database;GRANT ALL PRIVILEGES ON test_db.* TO 'test_user'@'localhost';
Output:
Query OK, 1 row affected (0.01 sec)
Flush privileges:
FLUSH PRIVILEGES;
Output:
Query OK, 0 rows affected (0.01 sec)
Populate the Database
Next, switch to the test_db database:
USE test_db;
Output:
Database changed
Create a
products
table to store sample records:CREATE TABLE products(product_id BIGINT PRIMARY KEY, product_name VARCHAR(50), category_name VARCHAR(50) ) ENGINE=INNODB;
Output:
Query OK, 0 rows affected (0.01 sec)
You can now add a few products to the products table by executing the commands below one by one:
INSERT INTO products (product_id, product_name, category_name) VALUES ('1', 'GAMING KEYBOARD', 'COMPUTER ACCESSORIES'); INSERT INTO products (product_id, product_name, category_name) VALUES ('2', 'OPTICAL MOUSE', 'COMPUTER ACCESSORIES'); INSERT INTO products (product_id, product_name, category_name) VALUES ('3', 'MOUSE PAD', 'COMPUTER ACCESSORIES'); INSERT INTO products (product_id, product_name, category_name) VALUES ('4', 'STEREO SYSTEM', 'ELECTRONICS'); INSERT INTO products (product_id, product_name, category_name) VALUES ('5', '32 INCH TV', 'ELECTRONICS'); INSERT INTO products (product_id, product_name, category_name) VALUES ('6', 'DVB-T2 RECEIVER', 'ELECTRONICS');
You should get the below output after executing each
Insert
statement:Query OK, 1 row affected (0.00 sec)
Next. confirm if the sample products were inserted successfully to the database by running the
Select
command below:SELECT * FROM products;
Your sample products should listed as shown below:
+------------+-----------------+----------------------+ | product_id | product_name | category_name | +------------+-----------------+----------------------+ | 1 | GAMING KEYBOARD | COMPUTER ACCESSORIES | | 2 | OPTICAL MOUSE | COMPUTER ACCESSORIES | | 3 | MOUSE PAD | COMPUTER ACCESSORIES | | 4 | STEREO SYSTEM | ELECTRONICS | | 5 | 32 INCH TV | ELECTRONICS | | 6 | DVB-T2 RECEIVER | ELECTRONICS | +------------+-----------------+----------------------+ 6 rows in set (0.00 sec)
Exit from MySQL server.
QUIT;
Output:
Bye!
Once you have created a
test_db
database,products
table, atest_user
, and added some sample products, you can now move on to creating the first stored procedure.
Creating a Stored Procedure
Stored Procedure Syntax
The basic syntax of creating a stored procedure in MySQL database is shown below:
DELIMITER &&
CREATE PROCEDURE PROCEDURE_NAME (PARAMETER_1, PARAMETER_2, PARAMETER_N...)
BEGIN
[SQL STATEMENT]
END &&
DELIMITER ;
The
DELIMITER &&
line at the beginning tells MySQL server to treat the following SQL statements as a single statement, rather than executing them individually. Another&&
is included on a later line to mark the end of this statement.PROCEDURE_NAME
is where the name of your stored procedure is declared.The procedure name is followed by a set of parentheses, and these enclose the parameters to your procedure. Stored procedures support comma-separated parameters, and this feature makes them more flexible. See the parameters section for more details.
The
BEGIN...END
commands enclose the SQL statement that you want to be executed by the stored procedure.In the end, the statement
DELIMITER ;
is issued again to change the delimiter back to the default value of;
Stored Procedure Parameters
Each parameter for a procedure has a type, name, and a data type, separated by spaces:
PARAMETER_TYPE PARAMETER_NAME DATA_TYPE
For example, to create a parameter of type IN
, named category
, with the VARCHAR
data type that has a length of 50 characters, use this syntax:
IN category VARCHAR(50)
MySQL supports three types of parameters:
IN
: The value of the parameter must be specified by the calling client. This value can not be changed by the stored procedure.For example, if you pass a MySQL session variable as an
IN
parameter to a procedure, and the procedure modifies this value in its statements, your session variable will remain unmodified after the procedure exits.OUT
: This type of parameter is also specified by the calling program, but its value can be changed by the stored procedure and retrieved by the calling program.Note that the stored procedure cannot access the initial value of a variable that is passed as an
OUT
parameter.INOUT
: A parameter of this type combines the behaviors ofIN
andOUT
parameters:The stored procedure can read the initial value of the parameter.
The parameter can be changed during stored procedure execution.
The changed value can be returned back to the calling program, if the calling program passed a variable as the parameter.
An Example Stored Procedure
After understanding the basic syntax, let’s create a simple stored procedure to filter products by category name. The category name will be supplied as an IN
parameter.
Log in to the MySQL server using the
test_user
’s credentials that you created when preparing the database:mysql -u test_user -p
Enter the password of the
test_user
and hit Enter to continue.You will get a
mysql >
prompt. Proceed by selecting thetest_db
:USE test_db;
Output:
Database changed.
Then, enter the SQL commands below to create a
filter_by_category
stored procedure:DELIMITER && CREATE PROCEDURE filter_by_category (IN category VARCHAR(50)) BEGIN SELECT * FROM products WHERE category_name=category; END &&
Output:
Query OK, 0 rows affected (0.00 sec)
Change the
DELIMITER
back to;
DELIMITER ;
If the code for creating the stored procedure ran successfully, you can now move on to executing the stored procedure.
Executing a Stored Procedure
In this step, we will call the stored procedure that we created above. We will follow this basic syntax:
CALL PROCEDURE_NAME (COMMA-SEPARATED PARAMETER VALUES);
To execute the
filter_by_category
stored procedure that we created above, enter the command below:CALL filter_by_category('COMPUTER ACCESSORIES');
The stored procedure should now output all products in the
COMPUTER ACCESSORIES
category because we have specifiedCOMPUTER ACCESSORIES
as a parameter:+------------+-----------------+----------------------+ | product_id | product_name | category_name | +------------+-----------------+----------------------+ | 1 | GAMING KEYBOARD | COMPUTER ACCESSORIES | | 2 | OPTICAL MOUSE | COMPUTER ACCESSORIES | | 3 | MOUSE PAD | COMPUTER ACCESSORIES | +------------+-----------------+----------------------+ 3 rows in set (0.00 sec) Query OK, 0 rows affected (0.01 sec)
Similarly, you can retrieve a list of all products from the
ELECTRONICS
category by executing the command below.CALL filter_by_category('ELECTRONICS') ;
Output:
+------------+-----------------+---------------+ | product_id | product_name | category_name | +------------+-----------------+---------------+ | 4 | STEREO SYSTEM | ELECTRONICS | | 5 | 32 INCH TV | ELECTRONICS | | 6 | DVB-T2 RECEIVER | ELECTRONICS | +------------+-----------------+---------------+ 3 rows in set (0.00 sec) Query OK, 0 rows affected (0.01 sec)
Our stored procedure worked as we expected. Next, we will learn how to drop the stored procedures if we no longer want them to execute again.
Deleting Stored Procedures
You can delete a MySQL stored procedure if you no longer want to use it or if you want to recreate it from scratch. The basic syntax of dropping the stored procedure is shown below:
DROP PROCEDURE IF EXISTS PROCEDURE_NAME;
For instance, to delete our filter_by_category
stored procedure, execute the MySQL command below:
DROP PROCEDURE IF EXISTS filter_by_category;
If the stored procedure exists, you will get the output shown below:
Query OK, 0 rows affected (0.00 sec)
That’s all when it comes to creating, using and dropping MySQL stored procedures.
More Information
You may wish to consult the following resources for additional information on this topic. While these are provided in the hope that they will be useful, please note that we cannot vouch for the accuracy or timeliness of externally hosted materials.
This page was originally published on