如何在mysql存储过程中使用WHILE,REPEAT和LOOP循环语句

55次阅读
没有评论

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

自动写代码机器人,免费开通

这篇文章将为大家详细讲解有关如何在 mysql 存储过程中使用 WHILE,REPEAT 和 LOOP 循环语句,文章内容质量较高,因此丸趣 TV 小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

MySQL 提供循环语句,允许我们根据条件重复执行一个 SQL 代码块其中有三个循环语句:WHILE,REPEAT 和 LOOP,我们接下来分别看下。首先是 WHILE 语句来看下语法:

WHILE expression DO
 statements
END WHILE

WHILE 循环在每次迭代开始时检查表达式。如果 expressionevaluates 为 TRUE,MySQL 将执行 WHILE 和 END WHILE 之间的语句,直到 expressionevaluates 为 FALSE。WHILE 循环称为预先测试条件循环,因为它总是在执行前检查语句的表达式。来看下流程图:

如何在 mysql 存储过程中使用 WHILE,REPEAT 和 LOOP 循环语句

完事咱们尝试在存储过程中使用 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_loopstored 存储过程:

CALL test_mysql_while_loop();

执行上面查询语句,得到以下结果:

mysql  CALL test_mysql_while_loop();
+------------+
| str |
+------------+
| 1,2,3,4,5, |
+------------+
1 row in set
Query OK, 0 rows affected

完事再来看 REPEAT 循环语句的语法结构:

REPEAT
 statements;
UNTIL expression
END REPEAT

上述 sql 首先被 mysql 执行,完事 mysql 会评估求值表达式 (expression),如果表达式(expression) 的计算结果为 FALSE,则 mysql 将重复执行该语句,直到该表达式计算结果为 TRUE。因为 REPEAT 循环语句在执行语句后检查表达式(expression),因此 REPEAT 循环语句也称为测试后循环。咱们来看下流程图:

如何在 mysql 存储过程中使用 WHILE,REPEAT 和 LOOP 循环语句

完事咱们再来使用 REPEAT 循环语句重写 test_mysql_while_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 表达式中没有分号(;)。执行上面查询语句,得到以下结果:

mysql  CALL mysql_test_repeat_loop();
+------------+
| str |
+------------+
| 1,2,3,4,5, |
+------------+
1 row in set
Query OK, 0 rows affected

最后咱们再来看一个使用 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;

上述 sql 具体作用如下:

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

在 LOOP 语句之前放置一个 loop_label 循环标签。

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

如果 x 的值是一个奇数,ITERATE 语句忽略它下面的所有内容,并开始一个新的迭代。

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

执行上面查询语句,得到以下结果:

mysql  CALL test_mysql_loop();
+-------------+
| str |
+-------------+
| 2,4,6,8,10, |
+-------------+
1 row in set
Query OK, 0 rows affected

完事咱们再来看下控制循环的两个关键词:

LEAVE 语句用于立即退出循环,而无需等待检查条件。LEAVE 语句的工作原理就类似 PHP,C/C++,java 等其他语言的 break 语句一样。

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

关于如何在 mysql 存储过程中使用 WHILE,REPEAT 和 LOOP 循环语句就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向 AI 问一下细节

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