zl程序教程

您现在的位置是:首页 >  数据库

当前栏目

MySQL存储过程参数的用法及说明

mysql存储 说明 用法 参数 过程
2023-06-13 09:20:05 时间
输入参数(IN):在调用存储过程中传递数据给存储过程的参数(在调用的存储过程必须具有实际值的变量 或者 字面值)

细节注意:下面的存储过程创建会报错,他的类型以及类型长度需要和创建表字段的类型和类型长度一致

创建一个存储过程:添加一个员工信息
DELIMITER $$
CREATE PROCEDURE procedure_test4(IN `p_name` VARCHAR,IN `p_call` VARCHAR)
BEGIN
INSERT INTO employees(`name`,`call`)
VALUES(`p_name`,`p_call`);
END $$

正确写法

创建一个存储过程:添加一个员工信息
DELIMITER $$
CREATE PROCEDURE procedure_test4(IN `p_name` VARCHAR(64),IN `p_call` VARCHAR(64))
BEGIN
INSERT INTO employees(`name`,`call`)
VALUES(`p_name`,`p_call`);
END $$

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jrDYIwVa-1640232786855)(C:/Users/15014/AppData/Roaming/Typora/typora-user-images/image-20211223112719116.jpg)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hcw4KheE-1640232786856)(C:/Users/15014/AppData/Roaming/Typora/typora-user-images/image-20211223112002450.jpg)]

现在来测试一下是否可以调用存储过程并且添加数据进去

先看一下表原来的数据

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tFaNe9UZ-1640232786856)(C:/Users/15014/AppData/Roaming/Typora/typora-user-images/image-20211223113244925.jpg)]

调用一下存储过程

CALL procedure_test4( 李四 , 321321 )

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-R7FXE03S-1640232786857)(C:/Users/15014/AppData/Roaming/Typora/typora-user-images/image-20211223113313119.jpg)]

再来看一下结果

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-L5L5sTMe-1640232786858)(C:/Users/15014/AppData/Roaming/Typora/typora-user-images/image-20211223113351902.jpg)]

输出参数(OUT):将存储过程中产生的数据返回给调用者,相当于Java方法的返回值,但不同的是一个存储过程可以有多个输出参数

例子:

创建一个存储过程:根据id查询出该员工姓名
DELIMITER $$
CREATE PROCEDURE procedure_test5(IN `p_id` INT(64),OUT `p_name` VARCHAR(64))
BEGIN
SELECT `name` INTO `p_name` FROM employees WHERE id=`p_id`;
END $$

创建没问题,接下来调用测试一下

SET @e_name=
CALL procedure_test5( 2 ,@e_name)
SELECT @e_name FROM DUAL

输入输出参数(INOUT) INOUT(输入输出参数)
DELIMITER $$
CREATE PROCEDURE procedure_test6(INOUT str VARCHAR(64))
BEGIN
把你传进来的值作为条件,查询出的结果再重新赋值给 str 返回出去
这里的 str 既当输入参数,也当输出参数
SELECT `name` INTO str FROM employees WHERE id=str;
END $$

创建没问题,接下来测试一下

SET @e_name= 2
CALL procedure_test6(@e_name)
SELECT @e_name FROM DUAL

也是没问题的,但在实际开发中 INOUT 建议少用,原因:代码的可读性会变差

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。


我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题

本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 MySQL存储过程参数的用法及说明