本篇文章给大家带来了关于mysql的相关知识,主要介绍了mysql存储过程参数的用法及说明,mysql存储过程的参数共有三种:in、out 、inout,下面一起来看一下,希望对大家有帮助。

推荐学习:mysql视频教程
MySQL存储过程的参数
MySQL存储过程的参数共有三种:
IN-
OUT INOUT
输入参数
- 输入参数(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)]](https://img.php.cn/upload/article/000/000/067/0aa456b5b4fd73dbdc6fab04347dd7c7-1.jpg)
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hcw4KheE-1640232786856)(C:/Users/15014/AppData/Roaming/Typora/typora-user-images/image-20211223112002450.jpg)]](https://img.php.cn/upload/article/000/000/067/0aa456b5b4fd73dbdc6fab04347dd7c7-2.jpg)
现在来测试一下是否可以调用存储过程并且添加数据进去
先看一下表原来的数据
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tFaNe9UZ-1640232786856)(C:/Users/15014/AppData/Roaming/Typora/typora-user-images/image-20211223113244925.jpg)]](https://img.php.cn/upload/article/000/000/067/0aa456b5b4fd73dbdc6fab04347dd7c7-3.jpg)
调用一下存储过程
请注意以下说明:1、本程序允许任何人免费使用。2、本程序采用PHP+MYSQL架构编写。并且经过ZEND加密,所以运行环境需要有ZEND引擎支持。3、需要售后服务的,请与本作者联系,联系方式见下方。4、本程序还可以与您的网站想整合,可以实现用户在线服务功能,可以让客户管理自己的信息,可以查询自己的订单状况。以及返点信息等相关客户利益的信息。这个功能可提高客户的向心度。安装方法:1、解压本系统,放在
CALL procedure_test4('李四','321321')![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-R7FXE03S-1640232786857)(C:/Users/15014/AppData/Roaming/Typora/typora-user-images/image-20211223113313119.jpg)]](https://img.php.cn/upload/article/000/000/067/80dba328a81c262153a79d295c6cb252-4.jpg)
再来看一下结果
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-L5L5sTMe-1640232786858)(C:/Users/15014/AppData/Roaming/Typora/typora-user-images/image-20211223113351902.jpg)]](https://img.php.cn/upload/article/000/000/067/80dba328a81c262153a79d295c6cb252-5.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视频教程









