Table of Contents

SQL CREATE PROCEDURE

Published

A stored procedure is a named collection of SQL statements that can be saved and reused. This article will explore the concept of stored procedures, their benefits, and how to create them.

1. Introduction

In the realm of database management, the SQL CREATE PROCEDURE statement stands as a fundamental tool for encapsulating and reusing SQL logic. Stored procedures are sets of SQL statements stored within the database. They can be invoked by applications, scripts, or other database objects, providing a more efficient and secure way to interact with data. This article delves into the intricacies of SQL stored procedures, explaining their benefits and how to create them.

Stored procedures are designed to streamline database operations by grouping SQL statements into a single named unit. This approach reduces code duplication and improves performance by minimizing the need to issue multiple individual queries across the network. By understanding and using stored procedures effectively, developers can build more robust and scalable database applications.

This article will guide you through the fundamentals of using CREATE PROCEDURE, demonstrating its flexibility and power through practical examples. We will explore different types of parameters, discuss approaches to securing the procedure logic, and consider the concept of temporary or session-specific procedures, offering a comprehensive overview suitable for both beginners and intermediate database users.

2. Benefits of Using Stored Procedures

Stored procedures offer several advantages that significantly impact the efficiency, security, and maintainability of database applications. Whether you are working with MySQL, PostgreSQL, or another SQL-based system, understanding these benefits is key to leveraging stored procedures effectively.

Reusability and Maintainability

One primary benefit of stored procedures is their reusability. Once a procedure is created, multiple applications and users can invoke it without rewriting the same SQL statements. This ensures consistency and reduces development effort. When changes become necessary, modifying the procedure in one place updates it everywhere it is used, simplifying maintenance and reducing the risk of introducing errors.

Encapsulating complex logic into a single, named object improves code organization. This clarity is particularly beneficial in large projects involving many developers. By adjusting stored procedures independently from application code, teams can adopt more agile development practices. Developers can focus on the application’s domain logic, while database administrators maintain and optimize the underlying SQL operations within the procedures.

Enhanced Security

Stored procedures contribute to stronger database security. By granting users permission to execute certain procedures rather than providing direct access to tables, you can restrict unauthorized data manipulation. Sensitive queries need not be exposed directly, reducing the surface area for attacks such as SQL injection.

Some database systems (e.g., Microsoft SQL Server with WITH ENCRYPTION) provide means to hide or obfuscate the source code of a procedure. Others, like MySQL or PostgreSQL, do not offer a straightforward built-in encryption for procedure definitions. In such cases, developers may rely on external tooling or limit access through permissions and roles. Although the exact encryption or obfuscation mechanisms vary, the principle remains: controlling access through procedures helps maintain data integrity, meet compliance requirements, and safeguard intellectual property.

Improved Performance

Stored procedures often improve performance by minimizing network overhead. Rather than sending full queries from the client for every request, you can send just the procedure call and any required parameters. The database server executes the logic internally, reducing round trips and improving response times.

Additionally, many database engines can cache the execution plan of a stored procedure after the first call. Subsequent executions may reuse this cached plan, speeding up processing. With well-designed procedures, the database engine can optimize data access paths, leading to more efficient query performance. Executing logic server-side also offloads computation from clients, resulting in a smoother user experience.

3. Creating a Basic Stored Procedure

Creating a stored procedure involves defining a sequence of SQL statements under a single name. Although the exact syntax and features differ slightly across database systems, the core concept remains the same. For example, MySQL uses CREATE PROCEDURE followed by a specific delimiter and CALL to invoke the procedure, while PostgreSQL also supports stored procedures and functions, often written in procedural languages like PL/pgSQL.

Fundamental Syntax

A general conceptual syntax for creating a stored procedure might look like:

Example (PostgreSQL):

-- In PostgreSQL, CREATE PROCEDURE is supported from PostgreSQL 11 onwards.
-- CREATE OR REPLACE PROCEDURE is supported from PostgreSQL 14 onwards.
-- It's important that the LANGUAGE clause matches the block syntax.
-- When using plpgsql language:
 
CREATE OR REPLACE PROCEDURE procedure_name(parameter_definitions)
LANGUAGE plpgsql
AS $$
BEGIN
  -- SQL statements
END;
$$;
-- PostgreSQL 11 and later support CREATE PROCEDURE
-- When using LANGUAGE sql in a procedure, a SELECT statement sends its output to the client if applicable,
-- but the procedure itself does not return a result set like a function does.
CREATE OR REPLACE PROCEDURE procedure_name()
LANGUAGE sql
AS $$
SELECT id, name FROM Employees WHERE department = 'Sales';
$$;
 
-- Use the CALL statement to execute the procedure.
-- The query results may be displayed to the client, but are not "returned" as a value.
CALL procedure_name();

Example (MySQL):

DELIMITER $$
CREATE PROCEDURE procedure_name(parameter_definitions)
BEGIN
  -- SQL statements
END$$
DELIMITER ;

While the LANGUAGE clause and exact keywords may vary, the idea is consistent: you specify a name, optionally define parameters, and then write the SQL logic between BEGIN and END. For instance, consider a table named Employees with columns id, name, and department. To create a procedure that selects all employees from the 'Sales' department, you might write something like:

DELIMITER $$
CREATE PROCEDURE GetSalesEmployees()
BEGIN
  SELECT id, name FROM Employees WHERE department = 'Sales';
END$$
DELIMITER ;
 
-- Use the CALL statement to execute the procedure
CALL GetSalesEmployees();

This example shows the logic encapsulated within a named unit. The exact syntax for procedure creation differs by system—for example, MySQL requires setting a delimiter and then using CALL GetSalesEmployees(); to invoke it—but the core concept remains the same in all systems that support stored procedures.

Executing a Stored Procedure

Once created, a stored procedure can be called by the client application or another part of the database. In MySQL, for example, you might use:

CALL GetSalesEmployees();

Other systems have similar commands. This invocation executes all statements within the procedure and returns results. The database engine processes the statements in sequence, providing a clean and controlled way to run predefined logic.

Including Parameters

Most SQL dialects allow parameters to make procedures more flexible. Parameters let you tailor the procedure’s behavior based on input values. For instance, to retrieve employees from a given department, you could write:

When using PostgreSQL procedures, you have two options:

  • With LANGUAGE sql, you must reference parameters using placeholders like $1, or alternatively use LANGUAGE plpgsql.
  • Here's an example using plpgsql:
CREATE OR REPLACE PROCEDURE GetEmployeesByDepartment(departmentName VARCHAR(50))
LANGUAGE plpgsql
AS $$
BEGIN
  -- In PL/pgSQL, you must assign the result or use PERFORM if you do not need it stored.
  PERFORM (SELECT id, name FROM Employees WHERE department = departmentName);
END;
$$;
 
-- This executes the SELECT internally. The procedure does not return a result set.
CALL GetEmployeesByDepartment('Marketing');

Or when using LANGUAGE sql:

CREATE OR REPLACE PROCEDURE GetEmployeesByDepartment(departmentName VARCHAR(50))
LANGUAGE sql
AS $$
SELECT id, name FROM Employees WHERE department = $1;
$$;
 
CALL GetEmployeesByDepartment('Marketing');

4. Working with Parameters

Parameters in stored procedures vary slightly by database. Common parameter modes include IN, OUT, and INOUT (or their equivalents), which determine how values are passed into and out of the procedure. While the exact keywords and syntax differ—MySQL uses IN, OUT, and INOUT parameters for stored procedures. PostgreSQL (11 and later) supports CREATE PROCEDURE with IN parameters only, and does not currently support OUT or INOUT parameters in procedures. Historically, developers used CREATE FUNCTION with RETURNS and OUT parameters for similar functionality. Always consult your database’s documentation for the precise parameter modes and their usage.

IN Parameters

IN parameters are read-only inputs. They pass a value to the procedure, which uses them during execution without returning the parameter’s modified value to the caller.

CREATE PROCEDURE GetOrderDetails(IN orderID INT)
LANGUAGE SQL
AS
BEGIN
  SELECT * FROM Orders WHERE order_id = orderID;
END;

To execute:

CALL GetOrderDetails(123);

OUT Parameters

OUT parameters return values to the caller. The procedure can assign values to these parameters, and after the call completes, the caller retrieves those values. This is useful for returning computed results or status codes.

CREATE PROCEDURE GetCustomerCountByCity(IN city_param VARCHAR(50), OUT customerCount INT)
LANGUAGE SQL
AS
BEGIN
  SELECT COUNT(*) INTO customerCount
  FROM Customers
  WHERE city = city_param;
END;

To invoke and access the result, you would typically declare a variable in your client session (depending on the client tool or programming language) and use that variable after calling the procedure.

INOUT Parameters

INOUT parameters combine both behaviors: they accept an input value and can also return an updated value. This allows the procedure to transform the input.

CREATE PROCEDURE UpdateProductPrice(INOUT price DECIMAL(10, 2), IN productID INT)
LANGUAGE SQL
AS
BEGIN
  UPDATE Products SET price = price WHERE product_id = productID;
  SELECT price INTO price FROM Products WHERE product_id = productID;
END;

You would pass a variable that holds an initial price and receive the updated price upon completion.

5. Encryption of Stored Procedures

Some database systems offer ways to hide or obfuscate the source code of stored procedures, commonly referred to as encryption or code obfuscation. While the exact implementation differs, the principle is to prevent unauthorized users from viewing the procedure’s SQL logic.

Using Encryption or Obfuscation Techniques

If your database platform supports it, you might specify a clause during procedure creation to encrypt or hide its definition. This often means the procedure’s text is stored in a non-readable format, making it difficult to obtain the logic by simply querying system tables or using built-in functions to display procedure definitions.

This is beneficial when the stored procedure contains proprietary algorithms, business logic, or sensitive queries that should remain confidential. Although not all systems implement this feature in the same way, the concept of protecting intellectual property and enhancing security through obscuring procedure code is common.

Limitations of Encryption

Encryption or obfuscation is not a silver bullet. Skilled users with high-level access or forensic tools might still extract logic from memory or backups. Also, certain operations, such as replicating encrypted procedures or debugging them, may be limited.

These techniques should be combined with other security measures like strict access controls, regular security audits, and proper backup procedures. Always consider the trade-offs before deciding to encrypt your procedure code.

6. Temporary Stored Procedures

While not universally supported (and commonly not available in popular systems like MySQL or PostgreSQL in a native form), some SQL databases (e.g., SQL Server) allow the creation
of temporary stored procedures. For those that do not, similar outcomes may be achieved via temporary tables, anonymous code blocks, or session-specific schemas. These might exist only for the duration of a connection and are automatically dropped afterward.

In some databases, you can create temporary procedures that behave similarly to temporary tables—existing only within a session and not cluttering the global namespace. Other systems may not support temporary stored procedures but might provide alternative mechanisms, such as creating procedures within temporary schemas or using inline code in anonymous blocks.

The key advantage of temporary procedures (where supported) is the isolation of logic for short-lived tasks. This can be useful for testing, ad-hoc data processing, or session-specific operations without affecting other users or the permanent database schema.

7. Modifying and Deleting Stored Procedures

SQL provides ways to alter or drop stored procedures. While the exact syntax and commands differ among systems, the concepts are similar.

Modifying Stored Procedures

If the database engine supports it, an ALTER PROCEDURE or equivalent command can update a procedure’s definition without dropping and recreating it. Adjusting parameters, changing SQL statements, or improving performance can be done centrally, which helps maintain stability and version control.

For example, you might modify a procedure to accept an additional parameter or incorporate new logic. Some databases require dropping and recreating the procedure if an exact ALTER syntax does not exist, so consult your system’s documentation.

Deleting Stored Procedures

When a procedure becomes obsolete, you can use a DROP PROCEDURE statement (or the system’s equivalent) to remove it from the database catalog. Before doing so, ensure that no other code depends on it. Removing a frequently used procedure without proper checks can break applications or other database routines.

As a best practice, maintain a versioned backup or documentation of your procedures. Test changes in a non-production environment to prevent unexpected disruptions.

8. Practices for Stored Procedures

Following best practices ensures that stored procedures remain efficient, secure, and easy to maintain. While the exact techniques vary among databases, the underlying principles are widely applicable.

Consistent Naming Conventions

Use descriptive and consistent naming for procedures. For example, GetCustomerDetails or UpdateOrderStatus clearly indicates their purpose. Good naming conventions improve readability, make troubleshooting easier, and facilitate onboarding new team members.

Proper Error Handling

Error handling mechanisms differ between systems. Some databases offer BEGIN ... EXCEPTION blocks, others have DECLARE HANDLER constructs, and still others provide language-specific error handling within stored procedures. Whichever method is available, ensure that your procedure gracefully handles unexpected conditions, logs meaningful error messages, and maintains data integrity.

Security Measures

Enforce strict permissions to ensure that only authorized roles or users can execute procedures. Validate all inputs to prevent SQL injection attacks. Where possible, avoid embedding raw dynamic SQL strings or make sure to properly sanitize them. Regular security audits and code reviews can help maintain a secure environment.

Code Optimization

Optimizing stored procedures can lead to significant performance gains. Avoid SELECT * and instead retrieve only the necessary columns. Ensure that appropriate indexes exist on tables used by the procedure. Keep transactions short and consider set-based operations rather than cursors or loops where possible. Minimizing resource usage and lock contention improves scalability and responsiveness.

9. Key Takeaways of SQL CREATE PROCEDURE

SQL stored procedures, introduced via CREATE PROCEDURE, are a cornerstone of many database architectures. They centralize and reuse logic, enhance security by controlling data access, and often boost performance through reduced network traffic and cached execution plans (where supported).

Parameters allow procedures to be flexible and dynamic. IN, OUT, and INOUT parameters empower developers to write more generic and powerful code. Security-enhancing features, such as code obfuscation, can help protect sensitive logic. Although not every system supports temporary procedures or identical parameter modes, the general principles remain the same across platforms.

As database technology evolves, stored procedures continue to offer a robust and secure means of encapsulating business logic at the data layer. By following best practices—consistent naming, proper error handling, careful security measures, and code optimization—you can fully realize the potential of stored procedures in a wide range of SQL-based environments.

Learning Resource: This content is for educational purposes. For the latest information and best practices, please refer to official documentation.

Text byTakafumi Endo

Takafumi Endo, CEO of ROUTE06. After earning his MSc from Tohoku University, he founded and led an e-commerce startup acquired by a major retail company. He also served as an EIR at Delight Ventures.

Last edited on