MySQL存储过程的参数共有三种:
IN
OUT
INOUT
输入参数(IN):在调用存储过程中传递数据给存储过程的参数(在调用的存储过程必须具有实际值的变量 或者 字面值)
细节注意:下面的存储过程创建会报错,他的类型以及类型长度需要和创建表字段的类型和类型长度一致
--创建一个存储过程:添加一个员工信息DELIMITER$$CREATEPROCEDUREprocedure_test4(IN`p_name`VARCHAR,IN`p_call`VARCHAR)BEGININSERTINTOemployees(`name`,`call`)VALUES(`p_name`,`p_call`);END$$
正确写法
--创建一个存储过程:添加一个员工信息DELIMITER$$CREATEPROCEDUREprocedure_test4(IN`p_name`VARCHAR(64),IN`p_call`VARCHAR(64))BEGININSERTINTOemployees(`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))BEGINSELECT`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 建议少用,原因:代码的可读性会变差
上一篇:如何解决1045无法登录mysql服务器
下一篇:Mysql中的Enum数据类型实例分析
mysql









