MySQL提供循环语句,允许我们根据条件重复执行一个SQL代码块其中有三个循环语句:WHILE
,REPEAT
和LOOP
,我们接下来分别看下。首先是WHILE
语句来看下语法:
WHILE expression DOstatementsEND WHILE
WHILE
循环在每次迭代开始时检查表达式。 如果expressionevaluates
为TRUE
,MySQL将执行WHILE
和END WHILE
之间的语句,直到expressionevaluates
为FALSE
。WHILE
循环称为预先测试条件循环,因为它总是在执行前检查语句的表达式。来看下流程图:
完事咱们尝试在存储过程中使用WHILE
循环语句,看个实例:
DELIMITER $$DROP PROCEDURE IF EXISTS test_mysql_while_loop$$CREATE PROCEDURE test_mysql_while_loop()BEGINDECLARE x INT;DECLARE str VARCHAR(255);SET x = 1;SET str = '';WHILE x <= 5 DOSET 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 setQuery OK, 0 rows affected
完事再来看REPEAT
循环语句的语法结构:
REPEATstatements;UNTIL expressionEND REPEAT
上述sql首先被mysql执行,完事mysql会评估求值表达式(expression
),如果表达式(expression
)的计算结果为FALSE
,则mysql将重复执行该语句,直到该表达式计算结果为TRUE
。因为REPEAT
循环语句在执行语句后检查表达式(expression
),因此REPEAT
循环语句也称为测试后循环。咱们来看下流程图:
完事咱们再来使用REPEAT
循环语句重写test_mysql_while_loop
存储过程:
DELIMITER $$DROP PROCEDURE IF EXISTS mysql_test_repeat_loop$$CREATE PROCEDURE mysql_test_repeat_loop()BEGINDECLARE x INT;DECLARE str VARCHAR(255);SET x = 1;SET str = '';REPEATSET str = CONCAT(str,x,',');SET x = x + 1; UNTIL x > 5END REPEAT;SELECT str;END$$DELIMITER ;
我们要注意的是UNTIL
表达式中没有分号(;
)。执行上面查询语句,得到以下结果:
mysql> CALL mysql_test_repeat_loop();+------------+| str |+------------+| 1,2,3,4,5, |+------------+1 row in setQuery OK, 0 rows affected
最后咱们再来看一个使用LOOP
循环语句的示例:
CREATE PROCEDURE test_mysql_loop()BEGINDECLARE x INT;DECLARE str VARCHAR(255);SET x = 1;SET str = '';loop_label: LOOPIF x > 10 THEN LEAVE loop_label;END IF;SET x = x + 1;IF (x mod 2) THENITERATE loop_label;ELSESET 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 setQuery OK, 0 rows affected
完事咱们再来看下控制循环的两个关键词:
LEAVE
语句用于立即退出循环,而无需等待检查条件。LEAVE
语句的工作原理就类似PHP,C/C++
,java等其他语言的break
语句一样。ITERATE
语句允许您跳过剩下的整个代码并开始新的迭代。ITERATE
语句类似于PHP
,C/C++
,Java
等中的continue
语句。
好啦,本次记录就到这里了。
如果感觉不错的话,请多多点赞支持哦。。。