mysql流控制语句(LOOP, REPEAT, WHILE)

Posted 超越昨天的自己就是进步

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql流控制语句(LOOP, REPEAT, WHILE)相关的知识,希望对你有一定的参考价值。

1.loop
语法:
[begin_label:] LOOP
    statement_list
END LOOP [end_label]
例子:
CREATE PROCEDURE doiterate(p1 INT) BEGIN label1: LOOP SET p1 = p1 + 1; IF p1 < 10 THEN ITERATE label1;// ITERATE can appear only within LOOPREPEAT, and WHILE statements. ITERATE means start the loop again.” END IF; LEAVE label1;// LEAVE can be used within BEGIN ... END or loop constructs (LOOPREPEATWHILE). END LOOP label1; SET @x = p1; END;
2.repeat
语法
[begin_label:] REPEAT
    statement_list
UNTIL search_condition
END REPEAT [end_label]

例子:
mysql> delimiter //

mysql> CREATE PROCEDURE dorepeat(p1 INT)
    -> BEGIN
    ->   SET @x = 0;
    ->   REPEAT
    ->     SET @x = @x + 1;
    ->   UNTIL @x > p1 END REPEAT;
    -> END
    -> //
Query OK, 0 rows affected (0.00 sec)

mysql> CALL dorepeat(1000)//
Query OK, 0 rows affected (0.00 sec)

mysql> SELECT @x//
+------+
| @x   |
+------+
| 1001 |
+------+
1 row in set (0.00 sec)

3.while
语法
[begin_label:] WHILE search_condition DO
    statement_list
END WHILE [end_label]
例子:
CREATE PROCEDURE dowhile()
BEGIN
  DECLARE v1 INT DEFAULT 5;

  WHILE v1 > 0 DO
    ...
    SET v1 = v1 - 1;
  END WHILE;
END;

4.label标记语法
[begin_label:] BEGIN
    [statement_list]
END [end_label]

[begin_label:] LOOP
    statement_list
END LOOP [end_label]

[begin_label:] REPEAT
    statement_list
UNTIL search_condition
END REPEAT [end_label]

[begin_label:] WHILE search_condition DO
    statement_list
END WHILE [end_label]




 















以上是关于mysql流控制语句(LOOP, REPEAT, WHILE)的主要内容,如果未能解决你的问题,请参考以下文章

MySQL数据库编程02

流程控制语句(MySQL/MariaDB )

mysql(while,repeat,loop) 循环语句的使用

MySQL 流程控制

存储过程之流程控制语句

在mysql,一个流程控制语句中可以保护多少个sql语句