欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

mysql存储过程之循环语句(WHILE,REPEAT和LOOP)用法分析

程序员文章站 2023-11-10 19:07:10
本文实例讲述了mysql存储过程之循环语句(while,repeat和loop)用法。分享给大家供大家参考,具体如下: mysql提供循环语句,允许我们根据条件重复执行一个sql代码...

本文实例讲述了mysql存储过程之循环语句(while,repeat和loop)用法。分享给大家供大家参考,具体如下:

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语句。

好啦,本次记录就到这里了。