文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL存储过程的创建、调用与管理的案例分析

2023-06-14 06:53

关注

这篇文章主要介绍MySQL存储过程的创建、调用与管理的案例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

存储过程简介

为什么要用存储过程?

MySQL5.0 版本开始支持存储过程。

大多数 SQL 语句都是针对一个或多个表的单条语句。并非所有的操作都那么简单。经常会有一个完整的操作需要多条语句才能完成。

存储过程简单来说,就是为以后的使用而保存的一条或多条 MySQL 语句的集合。可将其视为批处理文件。虽然他们的作用不仅限于批处理。

存储过程思想上很简单,就是数据库 SQL 语言层面的代码封装与重用。

存储过程的优点

  1. 通过把处理封装在容易使用的单元中,简化复杂的操作;

  2. 简化对变动的管理。如果表名、列名或业务逻辑有变化。只需要更改存储过程的代码,使用它的人员不会改自己的代码;

  3. 通常存储过程有助于提高应用程序的性能。当创建的存储过程被编译之后,就存储在数据库中。 但是,MySQL 实现的存储过程略有不同。MySQL 存储过程按需编译。在编译存储过程之后,MySQL 将其放入缓存中。MySQL 为每个连接维护自己的存储过程高速缓存。如果应用程序在单个连接中多次使用存储过程,则使用编译版本,否则存储过程的工作方式类似于查询;

  4. 存储过程有助于减少应用程序和数据库服务器之间的流量,因为应用程序不必发送多个冗长的 SQL 语句,而只用发送存储过程的名称和参数;

  5. 存储的程序对任何应用程序都是可重用的和透明的。存储过程将数据库接口暴露给所有应用程序,以便开发人员不必开发存储过程中已支持的功能;

  6. 存储的程序是安全的。数据库管理员可以向访问数据库中存储过程的应用程序授予适当的权限,而不向基础数据库表提供任何权限。

存储过程的缺点

  1. 如果使用大量存储过程,那么使用这些存储过程的每个连接的内存使用量将会大大增加。 此外,如果您在存储过程中过度使用大量逻辑操作,则 CPU 使用率也会增加,因为 MySQL 数据库最初的设计侧重于高效的查询,不利于逻辑运算;

  2. 存储过程的构造使得开发具有复杂业务逻辑的存储过程变得更加困难;

  3. 很难调试存储过程。只有少数数据库管理系统允许您调试存储过程。不幸的是,MySQL 不提供调试存储过程的功能;

  4. 开发和维护存储过程并不容易。开发和维护存储过程通常需要一个不是所有应用程序开发人员拥有的专业技能。这可能会导致应用程序开发和维护阶段的问题。

MySQL 中的存储过程

创建与调用过程

创建存储过程,代码如下所示:

-- 创建存储过程 create procedure mypro(in a int,in b int,out sum int) begin set sum = a+b; end;

运行结果如下

MySQL存储过程的创建、调用与管理的案例分析

也可以在 Navicat 客户端“函数”节点下查看过程,如下图所示:

MySQL存储过程的创建、调用与管理的案例分析

调用存储过程,代码如下所示:

call mypro(1,2,@s);-- 调用存储过程 select @s;-- 显示过程输出结果

运行结果

MySQL存储过程的创建、调用与管理的案例分析

存储过程语法解析

存储过程的参数

MySQL 存储过程的参数用在存储过程的定义,共有三种参数类型:

存储过程根据参数可分为四种类别:

1).没有参数的过程;

2).只有输入参数的过程;

3).只有输出参数的过程;

4).包含输入和输出参数的过程。

变量

MySQL 中的存储过程类似 java 中的方法。

既然如此,在存储过程中也同样可以使用变量。java 中的局部变量作用域是变量所在的方法,而 MySQL 中的局部变量作用域是所在的存储过程。

变量定义

DECLARE variable_name [,variable_name...] datatype [DEFAULT value];

declare用于声明变量;

variable_name表示变量名称;

datatype为 MySQL 的数据类型;

default用于声明默认值;

例如:

declare name varchar(20) default ‘jack'。

变量赋值

SET 变量名 = 表达式值 [,variable_name = expression ...]

在存储过程中使用变量,代码如下所示

use schooldb;-- 使用 schooldb 数据库-- 创建过程create procedure mypro1()begindeclare name varchar(20);set name = '丘处机';select * from studentinfo where studentname = name;end;-- 调用过程call mypro1();

运行结果

MySQL存储过程的创建、调用与管理的案例分析

流程控制语句

if 条件语句

IF 语句包含多个条件判断,根据结果为 TRUEFALSE执行语句,与编程语言中的 ifelse ifelse 语法类似。

定义存储过程,输入一个整数,使用 if 语句判断是正数还是负数,代码如下所示:

-- 创建过程create procedure mypro2(in num int)beginif num<0 then -- 条件开始select '负数';elseif num=0 thenselect '不是正数也不是负数';elseselect '正数';end if;-- 条件结束end;-- 调用过程call mypro2(-1);

运行结果

MySQL存储过程的创建、调用与管理的案例分析

case 条件语句

case是另一个条件判断的语句,类似于编程语言中的 choosewhen语法。MySQL 中的 case语句有两种语法
格式。

定义存储过程,输入一个整数,使用 case 语句判断是正数还是负数,代码如下所示:

-- 创建过程create procedure mypro3(in num int)begincase -- 条件开始when num<0 then select '负数';when num=0 then select '不是正数也不是负数';else select '正数';end case; -- 条件结束end;-- 调用过程call mypro3(1);

运行结果

MySQL存储过程的创建、调用与管理的案例分析

定义存储过程,输入一个整数,使用 case 语句判断是 1 还是 2,代码如下所示:

-- 创建过程create procedure mypro4(in num int)begincase num -- 条件开始when 1 then select '数值是 1';when 2 then select '数值是 2';else select '不是 1 也不是 2';end case; -- 条件结束end;-- 调用过程call mypro4(3);

运行结果

MySQL存储过程的创建、调用与管理的案例分析

两种 case 语法都可以实现条件判断,但第一种适合范围值判断,而第二种适合确定值判断。

while 循环语句

while语句的用法和 java中的 while循环类似。

定义存储过程,使用 while 循环输出 1 到 10 的累加和,代码如下所示:

-- 创建过程create procedure mypro5(out sum int)begindeclare num int default 0;set sum = 0;while num<10 do -- 循环开始set num = num+1;set sum = sum+num;end while; -- 循环结束end;-- 调用过程call mypro5(@sum);-- 查询变量值select @sum;

运行结果

MySQL存储过程的创建、调用与管理的案例分析

repeat 循环语句

repeat语句的用法和 java中的 do…while 语句类似,都是先执行循环操作,再判断条件,区别是 repeat表达
式值为 false时才执行循环操作,直到表达式值为 true停止。

定义存储过程,使用 repeat 循环输出 1 到 10 的累加和,代码如下所示:

-- 创建过程create procedure mypro6(out sum int)begindeclare num int default 0;set sum = 0;repeat-- 循环开始set num = num+1;set sum = sum+num;until num>=10end repeat; -- 循环结束end;-- 调用过程call mypro6(@sum);-- 查询变量值select @sum;

运行结果

MySQL存储过程的创建、调用与管理的案例分析

loop 循环语句

循环语句,用来重复执行某些语句。

执行过程中可使用 leave语句或 iterate 跳出循环,也可以嵌套 IF等判断语句。

leave语句效果相当于 java 中的 break,用来终止循环;

iterate语句效果相当于 java 中的 continue,用来结束本次循环操作,进入下一次循环。

定义存储过程,使用 loop 循环输出 1 到 10 的累加和,代码如下所示:

-- 创建过程create procedure mypro7(out sum int)begindeclare num int default 0;set sum = 0;loop_sum:loop-- 循环开始set num = num+1;set sum = sum+num;if num>=10 thenleave loop_sum;end if;end loop loop_sum; -- 循环结束end;-- 调用过程call mypro7(@sum);-- 查询变量值select @sum;

运行结果

MySQL存储过程的创建、调用与管理的案例分析

代码中的 loop_sum 相当于给循环贴个标签,方便多重循环时灵活操作。

存储过程的管理

存储过程的管理主要包括:显示过程、显示过程源码、删除过程。

比较简单的方式就是利用 navicat 客户端工具进行管理,鼠标点击操作即可,如下图所示:

MySQL存储过程的创建、调用与管理的案例分析

显示存储过程

SHOW PROCEDURE STATUS;

显示特定数据库的存储过程

SHOW PROCEDURE status where db = 'schooldb';

显示特定模式的存储过程,要求显示名称中包含“my”的存储过程

SHOW PROCEDURE status where name like '%my%';

显示存储过程“mypro1”的源码

SHOW CREATE PROCEDURE mypro1;

MySQL存储过程的创建、调用与管理的案例分析

删除存储过程“mypro1”

drop PROCEDURE mypro1;

以上是“MySQL存储过程的创建、调用与管理的案例分析”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯