当前位置:网站首页>mysql存储过程中的循环语句怎么写
mysql存储过程中的循环语句怎么写
2022-06-21 07:27:00 【亿速云】
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 statementsEND 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上面的存储过程中:
首先,我们str 重复构建字符串,直到x 变量的值 大于5。
然后,我们使用SELECT语句显示最终字符串。
请注意,如果我们不初始化 x变量,则其默认值为NULL。因此,WHILE循环语句中的条件始终是TRUE 并且您将具有无限循环,这不是期望的。
我们来测试一下test_mysql_while_loop存储过程:
CALL test_mysql_while_loop();
输出结果:

REPEAT循环
REPEAT 循环语句的语法如下:
REPEAT statementsUNTIL expressionEND 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();
输出结果:

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; 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 ;
测试一下:
call test_mysql_loop();

在这个例子中,
存储过程仅构造具有偶数的字符串,例如,2,4和6。
我们loop_label 在LOOP声明之前放置了一个循环标签。
如果值 x 大于10,则由于LEAVE语句而终止循环。
如果the的值x 是奇数,则ITERATE 语句忽略其下的所有内容并开始新的迭代。
如果the的值x 是偶数,则ELSE语句中的块将构建具有偶数的字符串。
以上就是“mysql存储过程中的循环语句怎么写”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注亿速云行业资讯频道。
边栏推荐
- Yield Guild Games 与 Discord 上的第一款 MMORPG ——Tatsumeeko 达成合作
- Ztmao theme cat WordPress Theme classic lost version /wp website template download station source code + global SEO function setting
- Kubernetes pod的生命周期
- Unittest use
- Wechat applet_ 4. Wxss template style
- Google Earth Engine(GEE)——美国本土岩性数据集
- The left column of WordPress implementation shows the article directory
- Realize the industry vision of decentralization, safety, accuracy and real-time price feeding
- Why do smart cities need digital twins?
- [flutter special topic] 72 graphic minimalist custom running lamp acemarquee yyds dry goods inventory
猜你喜欢

Sword finger offer (2nd Edition) brush questions | 04 Find in 2D array
![[graduation season - advanced technology Er]: the technology sharing of senior college students and the future encouragement](/img/97/179029022f42df7e267466948dd4c2.png)
[graduation season - advanced technology Er]: the technology sharing of senior college students and the future encouragement

远程辅助必备免费神器ToDesk远程控制软件(答辩,远程,调试,办公)必备远程工具

Unittest use

【osg】OSG开发(03)——构建MSVC版的osgQt库

rdkit | 药物分子进行片段分解

How do I install the visual studio code editor?

Google Earth engine (GEE) - US native lithology data set

Do you know all the extension racks of ThinkPHP?

Unittest使用
随机推荐
Digital twin smart server: information security monitoring platform
Life cycle of kubernetes pod
传输层 TCP首部-序号和确认号
【正则表达式每日一技】逃逸正则表达式中具有特殊含义的字符
怎么看小程序是谁开发的(查看小程序开发公司方法)
Privacy sandbox helps enterprises: how privacy technology protects user data and promotes business growth
Necessary free artifact for remote assistance todesk remote control software (defense, remote, debugging, office) necessary remote tools
微信小程序_6,网络数据请求
远程辅助必备免费神器ToDesk远程控制软件(答辩,远程,调试,办公)必备远程工具
【蓝桥杯单片机组】串口通信
Random random number class
Exists and in
Ztmao theme cat WordPress Theme classic lost version /wp website template download station source code + global SEO function setting
MATLAB 三维图(非常规)
Golang Sync. Use and principle of waitgroup
How do I install the visual studio code editor?
AdEx 治理投票:质押奖励减半
Crack the simple login system with NOP method
Cloud native enthusiast weekly: Chaos mesh upgraded to CNCF incubation project
IDM mobile terminal function upgrade description