13.6.5.6 REPEATStatements

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

重复REPEAT语句中的语句列 table,直到* search_condition *table 达式为 true。因此,REPEAT总是至少进入一次循环。 * statement_list *由一个或多个语句组成,每个语句以分号(;)语句定界符终止。

可以标记REPEAT语句。有关标签使用的规则,请参见第 13.6.2 节“声明标签”

Example:

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)