本教程操作环境:windows10系统、mysql 8.0版本、dell g3电脑。
mysql中的循环语句mysql提供循环语句,允许您根据条件重复执行一个sql代码块。
mysql是不支持for循环语句的,mysql只支持while循环、repeat循环、loop循环。
mysql提供循环语句,允许您根据条件重复执行一个sql代码块。mysql是不支持for循环语句的, mysql中有三个循环语句:while,repeat和loop。
我们将在以下部分中更详细地检查每个循环语句。
while循环
while语句的语法如下:
while expression do statementsend while
while循环在每次迭代开始时检查表达式。 如果expressionevaluates为true,mysql将执行while和end while之间的语句,直到expressionevaluates为false。 while循环称为预先测试条件循环,因为它总是在执行前检查语句的表达式。
下面的流程图说明了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_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循环
repeat循环语句的语法如下:
repeat statements;until expressionend repeat
首先,mysql执行语句,然后评估求值表达式(expression)。如果表达式(expression)的计算结果为false,则mysql将重复执行该语句,直到该表达式计算结果为true。
因为repeat循环语句在执行语句后检查表达式(expression),因此repeat循环语句也称为测试后循环。
下面的流程图说明了repeat循环语句的执行过程:
我们可以使用repeat循环语句重写test_mysql_while_loop存储过程,使用while循环语句:
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 setquery ok, 0 rows affected
loop,leave和iterate语句
有两个语句允许您用于控制循环:
leave语句用于立即退出循环,而无需等待检查条件。leave语句的工作原理就类似php,c/c++,java等其他语言的break语句一样。iterate语句允许您跳过剩下的整个代码并开始新的迭代。iterate语句类似于php,c/c++,java等中的continue语句。mysql还有一个loop语句,它可以反复执行一个代码块,另外还有一个使用循环标签的灵活性。
以下是使用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;
以上存储过程仅构造具有偶数字符串的字符串,例如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
【相关推荐:mysql视频教程】
以上就是mysql有for循环吗的详细内容。
