MySQL - CREATE PROCEDURE 创建存储过程语句
CREATE PROCEDURE 语句
存储过程是存储在 SQL 目录中的子例程,是 SQL 语句的片段。所有可以访问关系数据库(Java、Python、PHP 等)的应用程序都可以访问存储过程。
存储过程包含 IN 和 OUT 参数,或者两者兼有。如果您使用 SELECT 语句,它们可能会返回结果集。存储过程可以返回多个结果集。
您可以使用 MySQL 的 CREATE PROCEDURE 语句创建存储过程。
语法
以下是 CREATE PROCEDURE 语句的语法 -
CREATE PROCEDURE procedures_name (proc_parameter[,...]) routine_body
其中,procedure_name 是您需要创建的函数的名称,input_arguments 是函数的输入值,output_parameter 是函数的返回值。
示例
假设我们已经使用 CREATE TABLE 在 MySQL 数据库中创建了一个名为 Employee 的表,如下所示 -
CREATE TABLE Employee( Name VARCHAR(255), Salary INT NOT NULL, Location VARCHAR(255) );
以下是 MySQL 存储过程的示例。这里,我们将向 Employee 表中插入一列,并从用户处获取值。(通过输入参数)
DELIMITER // Create procedure myProcedure ( IN name VARCHAR(30), IN sal INT, IN loc VARCHAR(45)) BEGIN INSERT INTO Employee(Name, Salary, Location) VALUES (name, sal, loc); END // DELIMITER ;
调用存储过程
以下语句调用上面创建的存储过程。
CALL myProcedure ('Raman', 35000, 'Bangalore');
如果检索表的内容,您可以观察到新插入的行,如下所示 -
select * from employee;
输出
上述查询产生以下输出 -
Name | Salary | Location |
---|---|---|
Raman | 35000 | Bangalore |