MySQL存储过程参数有几种,怎样输入输出
导读:这篇文章主要为大家详细介绍了MySQL存储过程参数有几种,怎样输入输出的内容,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望对大家学习或工作能有帮助,接下来就跟随小编一起来学习吧。 MySQL存储过程的参数M...
这篇文章主要为大家详细介绍了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 $$
登录后复制
现在来测试一下是否可以调用存储过程并且添加数据进去
先看一下表原来的数据
调用一下存储过程
CALL procedure_test4('李四','321321')
登录后复制
再来看一下结果
输出参数
- 输出参数(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存储过程参数有几种,怎样输入输出”的内容了,通过以上内容的阐述,相信大家对MySQL存储过程参数有几种,怎样输入输出已经有了进一步的了解,如果想要了解更多相关的内容,欢迎关注网络,网络将为大家推送更多相关知识点的文章。
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: MySQL存储过程参数有几种,怎样输入输出
本文地址: https://pptw.com/jishu/649767.html