MySQL精讲之六:流程控制

来源:这里教程网 时间:2026-02-28 14:09:12 作者:

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。
【演示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;

【演示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)

【演示简单的循环结构】# 案例:批量插入,根据次数插入到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)$
【习题答案】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$
在这里插入图片描述在这里插入图片描述在这里插入图片描述

相关推荐