mysql存储过程之循环语句(WHILE,REPEAT和LOOP)用法分析
本文实例讲述了mysql存储过程之循环语句(WHILE,REPEAT和LOOP)用法。分享给大家供大家参考,具体如下:
MySQL提供循环语句,允许我们根据条件重复执行一个SQL代码块其中有三个循环语句:WHILE,REPEAT和LOOP,我们接下来分别看下。首先是WHILE语句来看下语法:
?1 2 3 | WHILE expression DO statements END WHILE |
WHILE循环在每次迭代开始时检查表达式。 如果expressionevaluates为TRUE,MySQL将执行WHILE和END WHILE之间的语句,直到expressionevaluates为FALSE。 WHILE循环称为预先测试条件循环,因为它总是在执行前检查语句的表达式。来看下流程图:
完事咱们尝试在存储过程中使用WHILE循环语句,看个实例:
?1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | 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存储过程:
?1 | CALL test_mysql_while_loop(); |
执行上面查询语句,得到以下结果:
?1 2 3 4 5 6 7 8 | mysql> CALL test_mysql_while_loop(); + ------------+ | str | + ------------+ | 1,2,3,4,5, | + ------------+ 1 row in set Query OK, 0 rows affected |
完事再来看REPEAT循环语句的语法结构:
?1 2 3 4 | REPEAT statements; UNTIL expression END REPEAT |
上述sql首先被mysql执行,完事mysql会评估求值表达式(expression),如果表达式(expression)的计算结果为FALSE,则mysql将重复执行该语句,直到该表达式计算结果为TRUE。因为REPEAT循环语句在执行语句后检查表达式(expression),因此REPEAT循环语句也称为测试后循环。咱们来看下流程图:
完事咱们再来使用REPEAT循环语句重写test_mysql_while_loop存储过程:
?1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | 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表达式中没有分号(;)。执行上面查询语句,得到以下结果:
?1 2 3 4 5 6 7 8 | mysql> CALL mysql_test_repeat_loop(); + ------------+ | str | + ------------+ | 1,2,3,4,5, | + ------------+ 1 row in set Query OK, 0 rows affected |
最后咱们再来看一个使用LOOP循环语句的示例:
?1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | 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语句中的块将使用偶数构建字符串。
执行上面查询语句,得到以下结果:
?1 2 3 4 5 6 7 8 | 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数据库计有所帮助。
原文链接:https://blog.csdn.net/luyaran/article/details/80984982
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。