返回顶部
首页 > 资讯 > 数据库 >mysql存储过程中的循环语句怎么写
  • 682
分享到

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

2024-04-02 19:04:59 682人浏览 八月长安
摘要

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

今天小编给大家分享一下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
   statements
END 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
 statements
UNTIL expression
END 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存储过程中的循环语句怎么写”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: mysql存储过程中的循环语句怎么写

本文链接: https://lsjlt.com/news/73580.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • mysql存储过程中的循环语句怎么写
    今天小编给大家分享一下mysql存储过程中的循环语句怎么写的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起...
    99+
    2024-04-02
  • mysql储存过程中循环语句有哪些
    mysql存储过程中提供while和repeat两种循环语句:while循环:根据条件重复执行代码块,条件为真时继续执行。repeat循环:先执行代码块,再检查条件是否为真,为假则再次执...
    99+
    2024-04-22
    mysql 代码可读性
  • mysql中执行存储过程的语句怎么写
    这篇文章主要介绍了mysql中执行存储过程的语句怎么写的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇mysql中执行存储过程的语句怎么写文章都会有所收获,下面我们一起来看看吧。...
    99+
    2024-04-02
  • MySQL REPEAT循环语句如何在存储过程中使用?
    众所周知,MySQL 为我们提供了循环语句,允许我们根据条件重复执行 SQL 代码块。 REPEAT循环语句就是此类循环语句之一。其语法如下 -REPEAT statements; UNTIL expression END REPEA...
    99+
    2023-10-22
  • 存储过程的使用(二)条件语句和循环语句
    条件语句部分 循环语句:有 **1.**REPEAT 直至条件表达式为True时执行的语句 UNTIL 条件表达式 END REPEAT; **2.**WHILE 条件表达式 DO 系列语句 END WHILE while 循环语句...
    99+
    2019-08-20
    存储过程的使用(二)条件语句和循环语句
  • mysql的for循环语句怎么写
    mysql的for循环语句怎么写?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。mysql的for循环语句怎么写MySQL是不支持for循环语句...
    99+
    2024-04-02
  • Oracle存储过程中跳出循环的写法
    记录exit和return的用法 exit用来跳出循环 loop IF V_KBP IS NULL THEN         ...
    99+
    2024-04-02
  • 存储过程中的MySQL PREPARE语句
    MySQL PREPARE语句用于在存储过程中动态准备和执行SQL语句。它的语法如下:```PREPARE statement_na...
    99+
    2023-09-27
    MySQL
  • 如何在mysql存储过程中使用WHILE,REPEAT和LOOP循环语句
    这篇文章将为大家详细讲解有关如何在mysql存储过程中使用WHILE,REPEAT和LOOP循环语句,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。MySQL...
    99+
    2024-04-02
  • plsql调用存储过程语句怎么写
    要调用存储过程,可以使用以下语句:```BEGINprocedure_name(parameter1, parameter2, .....
    99+
    2023-10-11
    plsql
  • mysql导出单个存储过程的sql语句怎么写
    小编给大家分享一下mysql导出单个存储过程的sql语句怎么写,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!在mysql中,可以使用“mysqldump -uroot -p -hlocalho...
    99+
    2024-04-02
  • MySQL存储过程中怎么控制循环次数
    在MySQL存储过程中,可以使用循环控制结构来控制循环次数,其中常用的循环结构有WHILE循环和FOR循环。 WHILE循环:在M...
    99+
    2024-04-30
    MySQL
  • Python3中的循环语句怎么写
    这篇文章主要介绍了Python3中的循环语句怎么写的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python3中的循环语句怎么写文章都会有所收获,下面我们一起来看看吧。Python3 循环语句在Python编程...
    99+
    2023-07-06
  • Oracle存储过程的控制和循环语句有哪些
    本篇内容主要讲解“Oracle存储过程的控制和循环语句有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Oracle存储过程的控制和循环语句有哪些”吧!1、控...
    99+
    2024-04-02
  • sql中循环语句怎么写
    sql 循环语句允许重复执行语句块,直到满足条件,共支持四种循环:while 循环:只要条件为真即重复执行;repeat 循环:语句块至少执行一次,直至条件为真;for 循环:按照指定步...
    99+
    2024-05-12
  • oracle中循环语句怎么写
    oracle 中有三种循环语句,语法分别是:for 循环:for loop_variable in [start_value, end_value] loop statement(s)...
    99+
    2024-04-30
    oracle
  • MySQL存储过程怎么循环插入数据
    这篇文章主要讲解了“MySQL存储过程怎么循环插入数据”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL存储过程怎么循环插入数据”吧!测试机器时经常要...
    99+
    2024-04-02
  • mysql写循环语句的方法
    mysql写循环语句的方法?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!mysql写循环语句的方法:1、使用while循环...
    99+
    2024-04-02
  • sql循环语句怎么写
    在SQL中,没有像其他编程语言那样的循环语句(例如for循环或while循环)。SQL是一种声明式的语言,主要用于查询和操作数据库中...
    99+
    2024-04-09
    sql
  • oracle循环语句怎么写
    oracle提供了两种类型的循环语句,用于重复执行代码:while循环:反复执行代码,直到条件不满足为止。for循环:将循环变量设置为指定范围内的值,然后执行代码。 Oracle循环语...
    99+
    2024-05-21
    oracle
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作