当前位置:首页 > 行业动态 > 正文

mysql存储过程输出参数

MySQL存储过程输出参数是通过 OUT关键字定义的,用于将计算结果从存储过程中返回给调用者。

MySQL存储过程是一种在数据库中存储的预编译SQL语句集合,可以通过调用存储过程名来执行,存储过程可以带有输入参数、输出参数和返回值,可以实现复杂的业务逻辑和数据操作。

mysql存储过程输出参数  第1张

创建存储过程

1、使用CREATE PROCEDURE语句创建存储过程:

CREATE PROCEDURE procedure_name (parameter1 datatype, parameter2 datatype, ...)
BEGIN
   SQL语句
END;

2、示例:创建一个名为add_employee的存储过程,接收两个输入参数emp_id和emp_name,并插入到employees表中。

DELIMITER //
CREATE PROCEDURE add_employee(IN emp_id INT, IN emp_name VARCHAR(255))
BEGIN
   INSERT INTO employees (id, name) VALUES (emp_id, emp_name);
END //
DELIMITER ;

调用存储过程

1、使用CALL语句调用存储过程:

CALL procedure_name(parameter1, parameter2, ...);

2、示例:调用add_employee存储过程,插入一条员工记录。

CALL add_employee(1, '张三');

修改存储过程

1、使用ALTER PROCEDURE语句修改存储过程:

ALTER PROCEDURE procedure_name (parameter1 datatype, parameter2 datatype, ...)
BEGIN
   SQL语句
END;

2、示例:修改add_employee存储过程,添加一个输出参数emp_age。

DELIMITER //
ALTER PROCEDURE add_employee(IN emp_id INT, IN emp_name VARCHAR(255), OUT emp_age INT)
BEGIN
   SELECT age INTO emp_age FROM employees WHERE id = emp_id;
   INSERT INTO employees (id, name, age) VALUES (emp_id, emp_name, emp_age);
END //
DELIMITER ;

删除存储过程

1、使用DROP PROCEDURE语句删除存储过程:

DROP PROCEDURE procedure_name;

2、示例:删除add_employee存储过程。

DROP PROCEDURE add_employee;
0