MySQL - CREATE PROCEDURE 语句



CREATE PROCEDURE 语句

存储过程是子程序,是存储在 SQL 目录中的 SQL 语句片段。所有可以访问关系数据库(Java、Python、PHP 等)的应用程序都可以访问存储过程。

存储过程包含输入和输出参数或两者兼有。如果使用 SELECT 语句,它们可能会返回结果集。存储过程可以返回多个结果集。

可以使用 MySQL CREATE PROCEDURE 语句创建过程。

语法

以下是 CREATE PROCEDURE 语句的语法:

CREATE PROCEDURE procedure_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;

输出

以上查询产生以下输出:

姓名 薪水 地点
Raman 35000 Bangalore
广告
© . All rights reserved.