本篇文章给大家带来了关于mysql的相关知识,主要介绍了mysql存储过程参数的用法及说明,mysql存储过程的参数共有三种:in、out 、inout,下面一起来看一下,希望对大家有帮助。
推荐学习:mysql视频教程
mysql存储过程的参数mysql存储过程的参数共有三种:
inout 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存储过程参数的用法及说明的详细内容。