MySQL存储过程参数的用法及说明

 更新时间:2022年08月17日 11:30:03   作者:꧁三七꧂  
这篇文章主要介绍了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 $$

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jrDYIwVa-1640232786855)(C:/Users/15014/AppData/Roaming/Typora/typora-user-images/image-20211223112719116.jpg)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hcw4KheE-1640232786856)(C:/Users/15014/AppData/Roaming/Typora/typora-user-images/image-20211223112002450.jpg)]

现在来测试一下是否可以调用存储过程并且添加数据进去

先看一下表原来的数据

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tFaNe9UZ-1640232786856)(C:/Users/15014/AppData/Roaming/Typora/typora-user-images/image-20211223113244925.jpg)]

调用一下存储过程

CALL procedure_test4('李四','321321')

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-R7FXE03S-1640232786857)(C:/Users/15014/AppData/Roaming/Typora/typora-user-images/image-20211223113313119.jpg)]

再来看一下结果

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-L5L5sTMe-1640232786858)(C:/Users/15014/AppData/Roaming/Typora/typora-user-images/image-20211223113351902.jpg)]

输出参数

  • 输出参数(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数据库压缩版本安装与配置详细教程

    今天教各位小伙伴怎么安装及配置Mysql数据库,文中有非常详细的图文解说及代码示例,对刚入门mysql的小伙伴们很有帮助,需要的朋友可以参考下
    2021-05-05
  • CentOS 7中源码安装MySQL 5.7.6+详细教程

    CentOS 7中源码安装MySQL 5.7.6+详细教程

    最近在CentOS 7中源码安装MySQL 5.7.6+,发现MySQL5.7.6+以后的安装方式真的与以前版本的MySQL安装方式大大的不同呀。不自己安装一把,你都不知道不同之处在哪,下面这篇文章是通过自己的安装过程总结的一篇安装教程,有需要的朋友们可以参考借鉴,下面来一起看看吧。
    2016-12-12
  • Mysql 5.7.18 解压版下载安装及启动mysql服务的图文详解

    Mysql 5.7.18 解压版下载安装及启动mysql服务的图文详解

    这篇文章主要介绍了Mysql 5.7.18 解压版下载安装及启动mysql服务的图文详解,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-05-05
  • 在MySQL中如何存取List<String>数据

    在MySQL中如何存取List<String>数据

    这篇文章主要介绍了在MySQL中如何存取List<String>数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07
  • 如何使用Maxwell实时同步mysql数据

    如何使用Maxwell实时同步mysql数据

    这篇文章主要介绍了如何使用Maxwell实时同步mysql数据,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下
    2021-04-04
  • MySQL执行update语句和原数据相同会再次执行吗

    MySQL执行update语句和原数据相同会再次执行吗

    这篇文章主要给大家介绍了关于MySQL执行update语句和原数据相同是否会再次执行的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用MySQL具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-04-04
  • Mysql 中文排序规则说明

    Mysql 中文排序规则说明

    这篇文章主要介绍了Mysql 中文排序规则说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02
  • 通过存储过程动态创建MySQL对象的流程步骤

    通过存储过程动态创建MySQL对象的流程步骤

    在当今数据驱动的世界中,高效的数据库管理至关重要,本文将展示如何通过存储过程自动化地创建各种 MySQL 数据库对象,通过这些方法,我们可以快速响应业务需求,提高数据库管理的灵活性和效率,需要的朋友可以参考下
    2024-10-10
  • mysql 5.7.21 解压版安装配置方法图文教程

    mysql 5.7.21 解压版安装配置方法图文教程

    这篇文章主要为大家详细介绍了mysql 5.7.21 解压版安装配置方法图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-05-05
  • Windows安装MySQL后怎么开启root的网络访问权限

    Windows安装MySQL后怎么开启root的网络访问权限

    Windows安装MySQL后默认只能本机访问,怎么开启网络访问,本文给大家介绍介绍了Windows安装MySQL后怎么开启root的网络访问权限,需要的朋友可以参考下
    2023-08-08

最新评论