【MySQL进阶之路 | 基础篇】流程控制

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 【MySQL进阶之路 | 基础篇】流程控制

1. 前言

针对MySQL的流程控制语句主要有这三类 :

  • 条件判断语句 : IF语句和CASE语句.
  • 循环语句 : LOOP, WHILE, REPEAT语句.
  • 跳转语句 : LEAVE与ITERATE语句.

2. 分支结构IF

(1). 语法结构

IF 表达式1 THEN 操作1
[ELSEIF 表达式2 THEN 操作2]……
[ELSE 操作N]END IF

类似Java中的if elseif else语句.

(2). 特点

  • 不同表达式对应不同的操作.
  • 必须使用在存储函数/存储过程中的BEGIN ... END语块中. 不能直接在普通的SQL查询语句中使用.

3. 分支结构之CASE

(1). 语法结构

情况一 :

类似Java的Switch(表达式) case.

CASE 表达式
WHEN 值1 THEN 结果1或语句1(如果是语句,需要加分号)
WHEN 值2 THEN 结果2或语句2(如果是语句,需要加分号)
...
ELSE 结果n或语句n(如果是语句,需要加分号)
END [case](如果是放在begin end中需要加上case,如果放在select后面不需要)

情况2 :

类似java中多层if.

CASE
WHEN 条件1 THEN 结果1或语句1(如果是语句,需要加分号)
WHEN 条件2 THEN 结果2或语句2(如果是语句,需要加分号)
...
ELSE 结果n或语句n(如果是语句,需要加分号)
END [case];(如果是放在begin end中需要加上case,如果放在select后面不需要)

(2). 例

例1 : 使用CASE情况1

例2 : 使用CASE情况2

4. 循环结构之LOOP

LOOP循环语句用来执行重复执行某些语句. LOOP内的语句一直执行直到循环终止(LEAVE语句).

(1). 格式 :

[add_loop]:LOOP
        # 循环体
        LEAVE [add_loop];
        # LEAVE跳出循环
END LOOP [add_loop];
# [add_loop]为LOOP循环的标签名称, 可以省略;

(2). 例 :

  • 标注名称add_loop有点类似于Java语言中的goto语句.

5.循环结构之WHILE

WHILE语句创建一个带条件判断的循环过程,条件判断为真,继续循环,否则退出循环.

(1). 格式

[while_label] : WHILE 条件 DO
        循环体
        END WHILE [while_label];
  • while_label为循环标签名.

(2). 例 :

  • WHILE循环语句类似于Java中的while语句.

6. 循环结构之REPEAT

REPEAT与WHILE不同的一点时,REPEAT首先会进行一次循环过程(WHILE语句是首先进行条件判断),然后再判断条件是否为真,条件判断在UNTIL语句中,如果满足条件,继续循环,否则退出.


由此看出,REPEAT语句类似于Java中的do-while循环.


(1). 格式

[repeat_label] : REPEAT
                        循环体
                        UNTIL 条件判断语句没有分号
                END REPEAT [repeat_label];

(2). 例

7. 跳转语句之LEAVE与ITERATE

(1). LEAVE

可以用在循环语句/BEGIN END包裹的SQL语块中.表示跳出循环/跳出程序体的操作.类似于Java语言中的break.

另外,LEAVE可以与标记名搭配.

标记名: BEGIN
            SQL语块
 
 
END;

(2). ITERATE

只能用在循环语句内表示重新开始循环,本次循环其后的SQL代码不执行.将循环顺序置于开头.类似于Java中的continue.

可以与标签名搭配.ITERATE 标签名.

8. 游标

(1). 为什么要用到游标

  • 虽然我们可以用过筛选条件WHERE/HAVING或通过限定返回记录的LIMIT返回一条记录.但无法在结果集中像指针一样,向前定位一条记录,向后定位一条记录. 或者随意定位到某条记录,并对记录的数据进行处理
  • 这个时候我们可以用到游标, 游标让我们能够对结果集中的每条记录进行定位,并可以对指向的记录的数据进行操作.游标让SQL这种面相集合的语言有了面向过程开发的能力.
  • SQL中,游标是一种临时的数据库对象,可以指向存储在数据库表中的数据行指针.这里游标充当指针的作用.
  • MySQL中游标可以在存储过程与存储函数中使用.

(2). 游标的使用

  • 游标必须声明在处理程序之前被声明,并且变量和条件必须在声明游标或处理程序前被声明.
  • 使用游标一般需要经历四个操作步骤.

(3). 操作步骤

(1). 声明游标

DECLARE cur_name CURSOR FOR select_statement;

使用SELECT获取数据结果集.此时还没有开始遍历.

(2). 打开游标

OPEN cur_name;

当我们定义好游标后,如果想使用游标,必须先打开游标.打开游标时SELECT语句的查询结果集就会送到游标工作区,为后面游标逐条读取结果集的记录做准备.

(3). 使用游标

FETCH cur_name INTO var_name, var1_name...

使用游标读取当前行,并将数据保存到当前变量中.游标指针指向下一行.当游标读取的数据行有多个列名时,则在INTO关键字后面赋值给多个变量即可.


游标的查询结果集中的字段数,必须和跟在INTO后面的变量数一致. 否则MySQL会报错.


(4). 关闭游标


CLOSE cur_name;

当使用完而且不再需要使用游标时,可以考虑关掉游标. 因为游标占据系统资源.如果不及时关闭,游标一直会保持到存储过程结束,影响运行效率.

(5). 例

# 创建存储过程“get_count_by_limit_total_salary()”,
# 声明IN参数 limit_total_salary,DOUBLE类型;声明
# OUT参数total_count,INT类型。
# 函数的功能可以实现累加薪资最高的几个员工的薪资值,
# 直到薪资总和达到limit_total_salary参数的值,
# 返回累加的人数给total_count。
 
CREATE PROCEDURE get_count_by_limit_total_salary(IN limit_total_salary DOUBLE, OUT total_count INT)
 
BEGIN 
      # 累加的总薪资
      DECLARE sum_salary DOUBLE DEFAULT 0.0;
      # 累加的总人头数
      DECLARE sum_count INT DEFAULT 0;
      # 从游标中获取的值
      DECLARE cur_salary DOUBLE;
      # 创建游标
      DECLARE emp_cursor CURSOR FOR 
      SELECT salary FROM employees ORDER BY salary DESC;
      # 打开游标
      OPEN emp_cursor;
      WHILE sum_salary < limit_total_salary DO 
            SET sum_count = sum_count + 1;
            FETCH emp_cursor INTO cur_salary;
            SET sum_salary = sum_salary + cur_salary;
      END WHILE;
      SET total_count = sum_count;
END;
 
CALL get_count_by_limit_total_salary(20000, @count);
SELECT @count;

(4). 小结

  • 游标是MySQL中的一个重要功能. 为逐条读取结果集中的数据提供了解决方案.游标可以在存储程序中使用,效率高,代码更简洁.
  • 使用游标也会带来性能问题. 在使用游标过程中,会对数据加锁,在业务并发量大时,不仅会影响业务之间的效率,还会消耗系统资源.造成内存不足.
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
28天前
|
SQL 存储 缓存
MySQL执行流程
本文介绍了MySQL的执行流程,分为server层和引擎层。server层包含连接器、查询缓存、解析器、预处理器、优化器等组件,负责SQL的接收、解析、优化及执行;引擎层负责数据的存储与读取。文章详细解释了各组件的功能,如连接器负责用户身份认证,查询缓存提高查询效率,解析器进行SQL的词法和语法分析,预处理器验证表和字段的存在性,优化器选择最优执行计划,最终由查询执行引擎完成查询并将结果返回给客户端。
MySQL执行流程
|
6月前
|
存储 SQL 关系型数据库
MySQL语句详解:从基础到进阶的全面指南
MySQL语句详解:从基础到进阶的全面指南
|
7月前
|
存储 关系型数据库 MySQL
MySQL数据库进阶第三篇(MySQL性能优化)
MySQL数据库进阶第三篇(MySQL性能优化)
|
7月前
|
存储 关系型数据库 MySQL
MySQL数据库进阶第六篇(InnoDB引擎架构,事务原理,MVCC)
MySQL数据库进阶第六篇(InnoDB引擎架构,事务原理,MVCC)
|
7月前
|
SQL 关系型数据库 MySQL
MySQL数据库进阶第五篇(锁)
MySQL数据库进阶第五篇(锁)
|
2月前
|
存储 SQL NoSQL
|
4月前
|
SQL 缓存 关系型数据库
揭秘MySQL一条SQL语句的执行流程
以上步骤共同构成了MySQL处理SQL语句的完整流程,理解这一流程有助于更有效地使用MySQL数据库,优化查询性能,及时解决可能出现的性能瓶颈问题。
132 7
|
6月前
|
存储 关系型数据库 MySQL
MySQL数据库开发进阶:精通数据库表的创建与管理22
【7月更文挑战第22天】数据库的创建与删除,数据表的创建与管理
57 1
|
6月前
|
NoSQL Java Redis
软件开发常见流程之宝塔初始化安装环境配置,Lam前面不选,直接跳商城,在宝塔内点击软件商城,安Mysql5.7,安java项目管理器,安Ngnix最新版,安Redis
软件开发常见流程之宝塔初始化安装环境配置,Lam前面不选,直接跳商城,在宝塔内点击软件商城,安Mysql5.7,安java项目管理器,安Ngnix最新版,安Redis
|
7月前
|
JSON 关系型数据库 MySQL
MySQL常用函数解读:从基础到进阶的全方位指南
MySQL常用函数解读:从基础到进阶的全方位指南
下一篇
开通oss服务