栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

MySQL存储过程的参数

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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 建议少用,原因:代码的可读性会变差

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/677949.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号