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

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

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

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

MySQL提供了循环语句,允许您根据条件重复执行一段SQL代码。有三种循环语句在MySQL: WHILE,REPEAT 和LOOP。

WHILE循环

WHILE语句的语法如下:

WHILE expression DO   statementsEND WHILE

WHILE 循环检查expression在每次迭代的开始。如果expression评估为TRUE,MySQL将 在评估statements之间执行 WHILEEND WHILE直到expression评估为止FALSE。WHILE 循环称为预测试循环,因为它在statements 执行之前检查表达式。

以下流程图说明了WHILE循环语句:

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

以下是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();

输出结果:

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

REPEAT循环

REPEAT 循环语句的语法如下:

REPEAT statementsUNTIL expressionEND REPEAT

首先,MySQL执行statements,然后评估expression。如果expression评估为FALSE,则MySQL statements 重复执行直到expression 评估为止TRUE。

因为REPEAT 循环语句expression 在执行后检查statements,所以REPEAT循环语句也称为测试后循环。

以下流程图说明了REPEAT循环语句:

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

我们可以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();

输出结果:

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

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();

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

在这个例子中,

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

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

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

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

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

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

文章标题:mysql存储过程中的循环语句怎么写,发布者:亿速云,转载请注明出处:https://worktile.com/kb/p/29431

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
亿速云的头像亿速云认证作者
上一篇 2022年9月24日 上午12:30
下一篇 2022年9月24日 上午12:32

相关推荐

  • windows驱动精灵屏保如何关闭

    驱动精灵屏保关闭方法: 1、打开驱动精灵进入主页点击“百宝箱”。 2、在“其他推荐”中找到“护眼模式”。 3、将“定时休息”边上的开关关闭即可。 感谢各位的阅读,以上就是“windows驱动精灵屏保如何关闭”的内容了,经过本文的学习后,相信大家对windows驱动精灵屏保如何关闭这一问题有了更深刻的…

    2022年9月13日
    89800
  • word字体放大少了一截怎么解决

    解决方法 1、 首先把文字选中(全选的快捷键是ctrl A)。 2、在选中的文字上面右击鼠标,选择“段落”。 3、找到间距一栏,里面有行距和设置值.我们可以看到设置成了固定值。 4、点击行距旁边的下拉框按钮,然后选择单倍行距,或者1.5倍行距等等.这里以单倍行距为例。 5、选择好之后如图,点击确定。…

    2022年9月18日
    65100
  • Redis之sentinel哨兵集群怎么部署

    一、Redis sentinel哨兵集群概述 (1)Redis哨兵概述 *Sentinel 哨兵:这是一个分布式系统,该进程是用于监控Redis集群中Master主服务器的工作状态,在Master主服务器发生故障时,可以实现Master和Slave服务器的秒级切换,保证系统有一个Master主服务器…

    2022年9月10日
    73500
  • windows edge浏览器和chrome的优点是什么

    edge浏览器chrome哪个好: 答:新版的edge浏览器更好一点。 在使用JavaScript测试后,edge浏览器以平均值103.5击败了谷歌Chrome,这说明它能够更好地处理开发者遇到的性能问题。 edge浏览器和chrome浏览器的优点: edge浏览器: 1、速度更快 edge浏览器已…

    2022年9月8日
    1.3K00
  • mysql索引类型有哪些

    索引类型有:1、B-树索引,使表中的每一行都会在索引上有一个对应值;2、哈希索引,可根据索引列对应的哈希值的方法获取表的记录行;3、普通索引,允许在定义索引的列中插入重复值和空值;4、少数索引,可以避免数据出现重复;5、主键索引,是为主键字段创建的索引;6、空间索引,是对空间数据类型的字段建立的索引…

    2022年9月20日
    3.0K00
  • jquery ajax如何改成同步

    在jquery中,ajax可以将async设置为false使其同步;默认情况下jquery中的ajax为异步请求,即“async:true”,通过设置参数“asycn:false”即可,语法为“$.ajax({async: false})”。 本文操作环境:windows10系统、jquery3.6…

    2022年9月10日
    2.6K00
  • 如何实现Weblogic SSRF漏洞复现

    一、使用docker搭建环境 docker安装及搭建环境教程:https://www.freebuf.com/sectool/252257.html 访问7001端口 二、漏洞复现步骤 1、漏洞存在页面 /uddiexplorer/SearchPublicRegistries.jsp 2、检查一下I…

    2022年9月24日
    64100
  • 远程代码执行漏洞实例分析

    0x01 认识 mongo-express mongo-express是一个MongoDB的Admin Web管理界面,使用NodeJS、Express、Bootstrap3编写而成。目前mongo-express应该是Github上Star非常多的MongoDB admin管理界面。部署方便,使用…

    2022年9月26日
    87500
  • MySQL的基础架构和日志系统实例分析

    一、MySQL基础架构 MySQL可以分为Server层和存储引擎层两部分 Server层包括连接器、查询缓存、分析器、优化器、执行器等,涵盖MySQL的大多数核心服务功能,以及所有的内置函数(如日期、时间、数学和加密函数等),所有跨存储引擎的功能都在这一层实现,比如存储过程、触发器、视图等 存储引…

    2022年9月16日
    81800
  • 如何通过jquery实现ajax调用

    能通过jquery来实现ajax调用。方法:1、用load()方法实现ajax请求,语法为“$(selector).load(url,…)”;2、用post()和get()方法,对应http请求中的POST、GET,语法为“$post(‘url’,{……

    2022年9月8日
    47400
注册PingCode 在线客服
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部