MySQL精讲之六:流程控制


本文摘自PHP中文网,作者coldplay.xixi,侵删。

免费学习推荐:mysql视频教程

文章目录

  • 分支结构
    • IF函数
    • case结构
    • IF结构
  • 循环结构

mysql中的流程控制和其他编程语言中的类似,也分为三种:顺序结构分支结构循环结构。前几篇文章中用到的基本上都是顺序结构(除了IF函数),下面主要针对分支结构和循环结构进行介绍。

分支结构

IF函数

语法:IF(表达式1,表达式2,表达式3)
说明:如果表达式1成立,则执行表达式2,否则执行表达式3

case结构

case结构有两种语法:
在这里插入图片描述
特点:

  • 作为表达式使用,嵌套在其他语句中使用,在BEGIN-END中和BEGIN-END外都可以使用。
  • 作为独立的语句使用,只能放在BEGIN-END中。
  • 如果省略ELSE,且所有的WHEN都不满足,则返回null。

1

2

3

4

5

6

7

【演示case作为独立的语句】# 创建存储过程,根据传入的成绩,显示等级:90-100显示A 、 80-90显示B、60-80显示C、否则显示DCREATE PROCEDURE test_case(IN score INT)BEGIN

    CASE

    WHEN score>=90 AND score<=100 THEN SELECT  'A';

    WHEN score>=80 THEN SELECT 'B';

    WHEN score>=60 THEN SELECT 'C';

    ELSE SELECT 'D';

    END CASE;END $CALL test_case(95)$

IF结构

语法:
if 条件1 then 语句1;
elseif 条件2 then 语句2;
...
[else 语句n;]
end if;

1

2

3

4

5

6

【演示IF结构】# 根据传入的成绩,显示等级:90-100显示A 、 80-90显示B、60-80显示C、否则显示DCREATE FUNCTION test_if(score INT) RETURNS CHARBEGIN

    IF score>=90 AND score<=100 THEN RETURN 'A';

    ELSEIF score>=80 THEN RETURN 'B';

    ELSEIF score>=60 THEN RETURN 'C';

    ELSE RETURN 'D';

    END IF;END $SELECT test_if(61)$

循环结构

mysql中的循环结构有下面三种:

名称语法特点
while在这里插入图片描述先判断后执行
repeat,类似Java中的do-wile语句在这里插入图片描述先执行后判断
loop在这里插入图片描述没有条件的死循环

可以在循环控制中使用的关键字有iterate(类似于Java中的continue)和leave(类似于Java中的break)

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

【演示简单的循环结构】# 案例:批量插入,根据次数插入到admin表中多条记录.CREATE PROCEDURE pro_while1(IN insertCount INT)BEGIN

    DECLARE i INT DEFAULT 1;

    WHILE i<=insertCount DO

        INSERT INTO admin(username,PASSWORD) VALUES(CONCAT('Lili',i),'666');

        SET i=i+1;

    END WHILE;END $CALL pro_while1(100)$--------------------------------------------------------------------------------------------【演示添加了leave语句的循环结构】# 案例:批量插入,根据次数插入到admin表中多条记录,>20则停止TRUNCATE TABLE admin$DROP PROCEDURE test_while1$CREATE PROCEDURE test_while1(IN insertCount INT)BEGIN

    DECLARE i INT DEFAULT 1;

    a:WHILE i<=insertCount DO

        INSERT INTO admin(username,PASSWORD) VALUES(CONCAT('xiaohua',i),'2333');

        IF i>=20 THEN LEAVE a;

        END IF;

        SET i=i+1;

    END WHILE a;END $CALL test_while1(100)$--------------------------------------------------------------------------------------------【演示添加了iterate的语句】# 案例:批量插入,根据次数插入到admin表中,直插入偶数次CREATE PROCEDURE test_while2(IN insertCount INT)BEGIN

    DECLARE i INT DEFAULT 0;

    a:WHILE i<=insertCount DO

        SET i=i+1;

        IF MOD(i,2)!=0 THEN ITERATE a;

        END IF;

        INSERT INTO admin(username,PASSWORD) VALUES(CONCAT('ming',i),'777');   

    END WHILE a;END $CALL test_while2(100)$

学习了mysql的流程控制,尝试完成下列习题
在这里插入图片描述

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

【习题答案】DROP TABLE IF EXISTS stringcontent;CREATE TABLE stringcontent(

    id INT PRIMARY KEY AUTO_INCREMENT,

    content VARCHAR(20)

    );DELIMITER $CREATE PROCEDURE test_pro1(IN insertCount INT)BEGIN

    DECLARE i INT DEFAULT 1;#定义一个循环变量i,表示插入次数

    DECLARE str VARCHAR(26) DEFAULT 'abcdefghijklmnopqrstuvwxyz';

    DECLARE strIndex INT DEFAULT 1;#代表起始索引

    DECLARE len INT DEFAULT 1;#代表截取的字符的长度

    WHILE i<=insertCount DO

        #两条生成随机数的指令原理相同:随机数*长度+1

        SET len=FLOOR(RAND()*(20-strIndex+1)+1);#产生一个随机整数,代表起始索引1-26

        SET strIndex=FLOOR(RAND()*20+1);#产生一个随机整数,代表截取长度(26-startIndex+1)

        INSERT INTO stringcontent(content) VALUES(SUBSTR(str,strIndex,len));

        SET i=i+1;#循环变量更新

    END WHILE;END $CALL test_pro1(10)$SELECT * FROM stringcontent$

更多相关免费学习推荐:mysql教程(视频)

以上就是MySQL精讲之六:流程控制的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

什么是mysql innodb事务隔离级别?

deepin v20如何安装mysql

mysql的tar包移动和解压及创建一个mysql的用户

怎么改mysql数据库的名字

mysql数据库简介与基本操作

如何设置mysql服务开机不启动?

mysql如何允许外网访问设置

详解mysql中url时区的陷阱该如何规避

phpmyadmin #1045错误无法登录mysql服务器怎么办?

mysql中常见的8种sql错误用法

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...