mysql存储过程中的循环语句怎么写

60次阅读
没有评论

共计 2637 个字符,预计需要花费 7 分钟才能阅读完成。

今天丸趣 TV 小编给大家分享一下 mysql 存储过程中的循环语句怎么写的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

mysql 存储过程中的循环语句有三种:1、WHILE 循环语句,语法“WHILE 条件表达式 DO 循环语句 END WHILE”;2、REPEAT 循环语句,语法“REPEAT 循环语句 UNTIL 条件表达式 END REPEAT”;3、LOOP 循环语句,语法“[begin_label:] LOOP 条件和循环语句列表 END LOOP [end_label]”。

本教程操作环境:windows7 系统、mysql8 版本、Dell G3 电脑。

MySQL 提供了循环语句,允许您根据条件重复执行一段 SQL 代码。有三种循环语句在 MySQL:WHILE,REPEAT 和 LOOP。

WHILE 循环

WHILE 语句的语法如下:

WHILE expression DO
 statements
END WHILE

WHILE 循环检查 expression 在每次迭代的开始。如果 expression 评估为 TRUE,MySQL 将 在评估 statements 之间执行  WHILE,END WHILE 直到 expression 评估为止 FALSE。WHILE 循环称为预测试循环,因为它在 statements 执行之前检查表达式。

以下流程图说明了 WHILE 循环语句:

以下是 WHILE 在存储过程中使用循环语句的示例:

DELIMITER $$
DROP PROCEDURE IF EXISTS test_mysql_while_loop$$ 
CREATE PROCEDURE test_mysql_while_loop ( ) 
 BEGIN
 DECLARE x INT;
 DECLARE str VARCHAR ( 255 );
 SET x = 1;
 SET str =  
 WHILE x  = 5 DO
 SET str = CONCAT( str, x,  ,  );
 SET x = x + 1;
 END WHILE;
 SELECT str;
END $$
DELIMITER ;

在 test_mysql_while_loop 上面的存储过程中:

首先,我们 str 重复构建字符串,直到 x 变量的值   大于 5。

然后,我们使用 SELECT 语句显示最终字符串。

请注意,如果我们不初始化  x 变量,则其默认值为 NULL。因此,WHILE 循环语句中的条件始终是 TRUE 并且您将具有无限循环,这不是期望的。

我们来测试一下 test_mysql_while_loop 存储过程:

CALL test_mysql_while_loop();

输出结果:

REPEAT 循环

REPEAT 循环语句的语法如下:

REPEAT
 statements
UNTIL expression
END REPEAT

首先,MySQL 执行 statements,然后评估 expression。如果 expression 评估为 FALSE,则 MySQL statements 重复执行直到 expression 评估为止 TRUE。

因为 REPEAT 循环语句 expression 在执行后检查 statements,所以 REPEAT 循环语句也称为测试后循环。

以下流程图说明了 REPEAT 循环语句:

我们可以 test_mysql_while_loop 使用 WHILE loop 语句重写上面使用 REPEAT loop 语句的存储过程:

DELIMITER $$
DROP PROCEDURE IF EXISTS mysql_test_repeat_loop $$ 
CREATE PROCEDURE mysql_test_repeat_loop ( ) BEGIN
 DECLARE x INT;
 DECLARE str VARCHAR ( 255 );
 SET x = 1;
 SET str =  
 REPEAT
 SET str = CONCAT( str, x,  ,  );
 SET x = x + 1;
 UNTIL x   5 
 END REPEAT;
 SELECT str;
END $$
DELIMITER ;

注意 UNTIL 表达式中没有分号(;)。

CALL mysql_test_repeat_loop();

输出结果:

LOOP,LEAVE 和 ITERATE 语句

有两个语句允许您控制循环:

LEAVE 语句允许您立即退出循环而无需等待检查条件。LEAVE 语句的作用类似于 PHP,C / C ++ 和 Java 等其他语言中的 break 语句。

ITERATE 语句允许您跳过其下的整个代码并开始新的迭代。ITERATE 语句类似于 PHP,C / C ++ 和 Java 中的 continue 语句。

MySQL 还为您提供了 LOOP 一个重复执行代码块的语句,并具有使用循环标签的额外灵活性。

以下是使用 LOOP 循环语句的示例:

DELIMITER $$
DROP PROCEDURE IF EXISTS test_mysql_loop $$ 
CREATE PROCEDURE test_mysql_loop() 
BEGIN
 DECLARE x INT;
 DECLARE str VARCHAR ( 255 );
 SET x = 1;
 SET str =  
 loop_label :LOOP
 IF x   10 THEN
 LEAVE loop_label;
 END IF;
 SET x = x + 1;
 IF ( x MOD 2 ) THEN
 ITERATE loop_label;
 ELSE 
 SET str = CONCAT( str, x,  ,  );
 END IF;
 END LOOP;
 SELECT str;
END $$
DELIMITER ;

测试一下:

call test_mysql_loop();

在这个例子中,

存储过程仅构造具有偶数的字符串,例如,2,4 和 6。

我们 loop_label   在 LOOP 声明之前放置了一个循环标签。

如果值  x 大于 10,则由于 LEAVE 语句而终止循环。

如果 the 的值 x 是奇数,则 ITERATE 语句忽略其下的所有内容并开始新的迭代。

如果 the 的值 x 是偶数,则 ELSE 语句中的块将构建具有偶数的字符串。

以上就是“mysql 存储过程中的循环语句怎么写”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,丸趣 TV 小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注丸趣 TV 行业资讯频道。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-13发表,共计2637字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)