mysql存储过程中的循环语句怎么写

网友投稿 422 2023-11-23

mysql存储过程中的循环语句怎么写

今天小编给大家分享一下mysql存储过程中的循环语句怎么写的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

mysql存储过程中的循环语句怎么写

mysql存储过程中的循环语句有三种:1、WHILE循环语句,语法“WHILE 条件表达式 DO 循环语句 END WHILE”;2、REPEAT循环语句,语法“REPEAT 循环语句 UNTIL 条件表达式 END REPEAT”;3、LOOP循环语句,语法“[begin_label:] LOOP 条件和循环语句列表 END LOOP [end_label]”。

本教程操作环境:windows7系统、mysql8版本、Dell G3电脑。

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 <= 5DO 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_loop存储过程:

CALL test_mysql_while_loop();

输出结果:

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 > 5END REPEAT;SELECT str; END $$ DELIMITER ;

注意UNTIL 表达式中没有分号(;)。

CALL mysql_test_repeat_loop();

输出结果:

LOOP,LEAVE和ITERATE语句

有两个语句允许您控制循环:

LEAVE语句允许您立即退出循环而无需等待检查条件。LEAVE语句的作用类似于PHP,C / C ++和Java等其他语言中的 break 语句。

ITERATE语句允许您跳过其下的整个代码并开始新的迭代。ITERATE语句类似于PHP,C / C ++和Java中的continue语句。

MySQL还为您提供了LOOP一个重复执行代码块的语句,并具有使用循环标签的额外灵活性。

以下是使用LOOP 循环语句的示例:

DELIMITER$$ DROP PROCEDURE IF EXISTS test_mysql_loop $$  CREATE PROCEDURE test_mysql_loop()  BEGIN   DECLARE x INT;DECLAREstr VARCHAR (255 );   SET x = 1;   SET str = ;   loop_label :LOOP     IF x > 10 THEN       LEAVE loop_label;     ENDIF;SET x = x + 1;     IF ( x MOD 2 ) THEN       ITERATE loop_label;     ELSE        SET str = CONCAT( str, x, , );     ENDIF;END LOOP;   SELECT str; END $$ DELIMITER ;

测试一下:

call test_mysql_loop();

在这个例子中,

存储过程仅构造具有偶数的字符串,例如,2,4和6。

我们loop_label  在LOOP声明之前放置了一个循环标签。

如果值  x 大于10,则由于LEAVE语句而终止循环。

如果the的值x 是奇数,则ITERATE 语句忽略其下的所有内容并开始新的迭代。

如果the的值x 是偶数,则ELSE语句中的块将构建具有偶数的字符串。

以上就是“mysql存储过程中的循环语句怎么写”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注行业资讯频道。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:盘点五大国产数据库厂商
下一篇:再聊聊数据库国产化替代
相关文章

 发表评论

暂时没有评论,来抢沙发吧~