[MySQL]流程控制语句

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 本文介绍了MySQL中的选择语句(if和case)和循环语句(while、repeat、loop)的使用方法,并通过具体示例展示了如何在存储过程中实现这些语句。内容包括输入员工名获取部门名称的if和case示例,以及计算1到n总和的while、repeat和loop示例。文章旨在帮助读者理解MySQL流程控制语句的基本格式和使用方法。

【版权声明】未经博主同意,谢绝转载!(请尊重原创,博主保留追究权)
https://developer.aliyun.com/article/1634556
出自【进步*于辰的博客

参考笔记三,P32.5。

用于测试的数据表:
在这里插入图片描述

1、选择语句

需求:输入员工名emp_name,获取部门id对应的部门名称。

1.1 if

格式:

if 条件1 then 语句1 elseif 条件2 then 语句2 else 语句3 end if;

示例:

CREATE DEFINER=`root`@`localhost` PROCEDURE `P_test`(IN `emp_name` varchar(20))
BEGIN
    declare deptId int default 0;
    select dept_id into deptId from emps where name = emp_name;

    IF deptId = 1 THEN
        select '开发部' from dual;
    ELSEif deptId = 2 THEN
        select '策划部' from dual;
    else
        select '其他部门' from dual;
    END IF;
END

测试:
在这里插入图片描述
测试结果:
在这里插入图片描述

1.2 case

1.2.1 形式一

格式:

case when 条件1 then 语句1 when 条件2 then 语句2 else 语句3 end case;

示例:

CREATE DEFINER=`root`@`localhost` PROCEDURE `P_test`(IN `emp_name` varchar(20))
BEGIN
    declare deptId int default 0;
    select dept_id into deptId from emps where name = emp_name;

    case
    when deptId = 1 THEN
        select '开发部' from dual;
    when deptId = 2 THEN
        select '策划部' from dual;
    else
        select '其他部门' from dual;
    END case;
END

1.2.2 形式二

格式:

case 参数 when1 then 语句1 when2 then 语句2 else 语句3 end case;

示例:

CREATE DEFINER=`root`@`localhost` PROCEDURE `P_test`(IN `emp_name` varchar(20))
BEGIN
    declare deptId int default 0;
    select dept_id into deptId from emps where name = emp_name;

    case deptId
    when 1 THEN
        select '开发部' from dual;
    when 2 THEN
        select '策划部' from dual;
    else
        select '其他部门' from dual;
    END case;
END

2、循环语句

需求:输入一个数n,计算1 ~ n的总和。

2.1 while

格式:

while 结束条件 do 语句 end while;

示例:

CREATE DEFINER=`root`@`localhost` PROCEDURE `P_test`(IN n int)
BEGIN
    declare sum int default 0;

    while n > 0
    do
        set sum = sum + n;
        set n = n - 1;
    end while;

    select sum;
END

测试:
在这里插入图片描述
测试结果:
在这里插入图片描述

2.2 repeat

格式:

repeat 语句 until 结束条件 end repeat;

示例:

CREATE DEFINER=`root`@`localhost` PROCEDURE `P_test`(IN n int)
BEGIN
    declare sum int default 0;

    REPEAT
        set sum = sum + n;
        set n = n - 1;
    UNTIL n < 0 end REPEAT;

    select sum;
END

2.3 loop

格式:

xx:loop if 条件1 then [leave xx;] end if; if 条件2 then [iterate xx;] end if; end loop xx
// leave类似break(必须有,作为循环终止);iterate类似continue。

示例:

CREATE DEFINER=`root`@`localhost` PROCEDURE `P_test`(IN n int)
BEGIN
    declare sum int default 0;

    calSum: loop
        if n < 0 then
            leave calSum;// leave 类似于 break
        end if;

        set n = n - 1;

        if n = 5 then
            iterate calSum;// iterate 类似于 continue
        end if;

        set sum = sum + n;
    end loop calSum;

    select sum;
END

n < 0时,循环结束;当n = 5时,跳过此次循环。当然,这个例子的测试结果不是55。

最后

本文中的例子是为了方便大家了解MySQL流程控制语句的格式及使用而简单举例的,不一定有实用性,仅是抛砖引玉。

如果大家想要了解存储过程,可查阅博文《[MySQL]存储过程》。

本文完结。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
7月前
|
SQL 关系型数据库 MySQL
MySQL流程控制语句
MySQL流程控制语句
|
存储 SQL 关系型数据库
MySQL触发器里的流程控制语句 case when .. then else ... end;组合+继承;高级数据库复习
MySQL触发器里的流程控制语句 实际上就是if 与 if else 我们的流程控制语句可以在业务实现类实现判断 也可以通过数据库MySQL触发器来实现流程控制语句
244 0
MySQL触发器里的流程控制语句 case when .. then else ... end;组合+继承;高级数据库复习
|
关系型数据库 MySQL
mysql流程控制语句
mysql流程控制语句
81 0
|
18天前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
32 1
|
20天前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
35 4
|
2月前
|
存储 关系型数据库 MySQL
Mysql(4)—数据库索引
数据库索引是用于提高数据检索效率的数据结构,类似于书籍中的索引。它允许用户快速找到数据,而无需扫描整个表。MySQL中的索引可以显著提升查询速度,使数据库操作更加高效。索引的发展经历了从无索引、简单索引到B-树、哈希索引、位图索引、全文索引等多个阶段。
64 3
Mysql(4)—数据库索引
|
27天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
150 1
|
29天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
85 2
|
1月前
|
存储 关系型数据库 MySQL
MySQL vs. PostgreSQL:选择适合你的开源数据库
在众多开源数据库中,MySQL和PostgreSQL无疑是最受欢迎的两个。它们都有着强大的功能、广泛的社区支持和丰富的生态系统。然而,它们在设计理念、性能特点、功能特性等方面存在着显著的差异。本文将从这三个方面对MySQL和PostgreSQL进行比较,以帮助您选择更适合您需求的开源数据库。
118 4
|
15天前
|
运维 关系型数据库 MySQL
安装MySQL8数据库
本文介绍了MySQL的不同版本及其特点,并详细描述了如何通过Yum源安装MySQL 8.4社区版,包括配置Yum源、安装MySQL、启动服务、设置开机自启动、修改root用户密码以及设置远程登录等步骤。最后还提供了测试连接的方法。适用于初学者和运维人员。
123 0