意见箱
恒创运营部门将仔细参阅您的意见和建议,必要时将通过预留邮箱与您保持联络。感谢您的支持!
意见/建议
提交建议

MySQL存储过程的参数如何使用

来源:恒创科技 编辑:恒创科技编辑部
2023-12-21 02:59:59

这篇文章主要介绍“MySQL存储过程的参数如何使用”,在日常操作中,相信很多人在MySQL存储过程的参数如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL存储过程的参数如何使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

MySQL存储过程的参数

MySQL存储过程的参数共有三种:


MySQL存储过程的参数如何使用

IN

OUT

INOUT

输入参数

输入参数(IN):在调用存储过程中传递数据给存储过程的参数(在调用的存储过程必须具有实际值的变量 或者 字面值)

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

--创建一个存储过程:添加一个员工信息
DELIMITER$$
CREATEPROCEDUREprocedure_test4(IN`p_name`VARCHAR,IN`p_call`VARCHAR)
BEGIN
INSERTINTOemployees(`name`,`call`)
VALUES(`p_name`,`p_call`);
END$$

正确写法

--创建一个存储过程:添加一个员工信息
DELIMITER$$
CREATEPROCEDUREprocedure_test4(IN`p_name`VARCHAR(64),IN`p_call`VARCHAR(64))
BEGIN
INSERTINTOemployees(`name`,`call`)
VALUES(`p_name`,`p_call`);
END$$

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

先看一下表原来的数据

调用一下存储过程

CALLprocedure_test4('李四','321321')

再来看一下结果

输出参数

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

例子:

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

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

SET@e_name=''
CALLprocedure_test5('2',@e_name)
SELECT@e_nameFROMDUAL

输入输出参数(INOUT)

--INOUT(输入输出参数)
DELIMITER$$
CREATEPROCEDUREprocedure_test6(INOUTstrVARCHAR(64))
BEGIN
--把你传进来的值作为条件,查询出的结果再重新赋值给str返回出去
--这里的str既当输入参数,也当输出参数
SELECT`name`INTOstrFROMemployeesWHEREid=str;
END$$

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

SET@e_name='2'
CALLprocedure_test6(@e_name)
SELECT@e_nameFROMDUAL

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

到此,关于“MySQL存储过程的参数如何使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注恒创网站,小编会继续努力为大家带来更多实用的文章!

上一篇: 什么是死锁?聊聊对MySQL死锁的理解 下一篇: MySQL中流式查询及游标查询的方式是什么