MySQL 存储过程循环
摘要:在本教程中,您将学习如何使用各种MySQL的循环语句包括
WHILE
,REPEAT
和LOOP
运行反复基于条件的代码块。
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
上面的存储过程中:
请注意,如果我们不初始化 x
变量,则其默认值为NULL
。因此,WHILE
循环语句中的条件始终是TRUE
并且您将具有无限循环,这不是期望的。
我们来测试一下test_mysql_while_loop
存储过程:
CALL test_mysql_while_loop();
+------------+ | str | +------------+ | 1,2,3,4,5, | +------------+ 1 row in set (0.01 sec)
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();
+------------+ | str | +------------+ | 1,2,3,4,5, | +------------+ 1 row in set (0.00 sec)
LOOP,LEAVE和ITERATE语句
有两个语句允许您控制循环:LEAVE
语句允许您立即退出循环而无需等待检查条件。LEAVE
语句的作用类似于PHP,C / C ++和Java等其他语言中的break
语句。ITERATE
语句允许您跳过其下的整个代码并开始新的迭代。ITERATE
语句类似于PHP,C / C ++和Java中的continue
语句。
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 ;
mysql> call test_mysql_loop(); +-------------+ | str | +-------------+ | 2,4,6,8,10, | +-------------+ 1 row in set (0.00 sec)在这个例子中,
- 存储过程仅构造具有偶数的字符串,例如,2,4和6。
- 我们
loop_label
在LOOP
声明之前放置了一个循环标签。 - 如果值
x
大于10
,则由于LEAVE
语句而终止循环。 - 如果the的值
x
是奇数,则ITERATE
语句忽略其下的所有内容并开始新的迭代。 - 如果the的值
x
是偶数,则ELSE
语句中的块将构建具有偶数的字符串。