• 技术文章 >数据库 >mysql教程

    mysql存储过程中的循环语句有哪些

    青灯夜游青灯夜游2022-06-20 11:51:29原创274

    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之间执行 WHILEEND WHILE直到expression评估为止FALSE。WHILE 循环称为预测试循环,因为它在statements 执行之前检查表达式。

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

    1.jpg

    以下是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上面的存储过程中:

    请注意,如果我们不初始化 x变量,则其默认值为NULL。因此,WHILE循环语句中的条件始终是TRUE 并且您将具有无限循环,这不是期望的。

    我们来测试一下test_mysql_while_loop存储过程:

    CALL test_mysql_while_loop();

    输出结果:

    2.png

    REPEAT循环

    REPEAT 循环语句的语法如下:

    REPEAT
     statements
    UNTIL expression
    END REPEAT

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

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

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

    3.jpg

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

    输出结果:

    4.png

    LOOP,LEAVE和ITERATE语句

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

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

    5.png

    在这个例子中,

    【相关推荐:mysql视频教程

    以上就是mysql存储过程中的循环语句有哪些的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:mysql
    上一篇:mysql怎么查询临时表 下一篇:一起来聊聊数据库拉链表
    20期PHP线上班

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• 为什么选择mysql• mysql怎么开启错误日志• mysql怎么删除数据库• 一起聊聊MySQL全局锁• mysql substring()函数怎么用
    1/1

    PHP中文网