Documentation Home

13.6.5.6 重复语句

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

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

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

例子:

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)