MySQL存储过程参数的用法及说明
目录
- MySQL存储过程的参数
- 输入参数
- 输出参数
- 输入输出参数(INOUT)
MySQL存储过程的参数 MySQL存储过程的参数共有三种:
IN
OUT
INOUT
输入参数
- 输入参数(IN):在调用存储过程中传递数据给存储过程的参数(在调用的存储过程必须具有实际值的变量 或者 字面值)
-- 创建一个存储过程:添加一个员工信息DELIMITER $$CREATE PROCEDURE procedure_test4(IN `p_name` VARCHAR,IN `p_call` VARCHAR)BEGININSERT 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))BEGININSERT 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))BEGINSELECT `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存储过程参数的用法及说明】以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
推荐阅读
- FPGA20个例程|FPGA 20个例程篇(7.FLASH读写断电存储)
- Shiro授权过程
- mysql|mysql left join on 左表查询
- MySQL|深入浅出MySQL灵魂十连问,你真的有把握吗()
- MySQL|来自大厂面试官的MySQL灵魂十连问,你真的有把握全部回答出来吗()
- MySQL灵魂十连
- 10分钟在服务器部署好Jenkins的详细过程
- Activity|Activity 启动过程
- 汽车出行|材料检测、给电池做CT、针刺试验……蜂巢能源公开电池研发全过程
- 【有码教育】PHP环境(apache|【有码教育】PHP环境(apache,PHP,Mysql)详细配置方法