MySQL 9.0 版本注意事項
[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]標籤允許用於 BEGIN ... END 區塊,以及 LOOP、REPEAT 和 WHILE 陳述式。這些陳述式標籤的使用遵循以下規則:
begin_label必須後接冒號。begin_label可以不指定end_label。如果存在end_label,則它必須與begin_label相同。不能在沒有
begin_label的情況下指定end_label。相同巢狀層級的標籤必須是不同的。
標籤最多可達 16 個字元長。
若要在已標記的結構中參照標籤,請使用 ITERATE 或 LEAVE 陳述式。以下範例使用這些陳述式來繼續迭代或終止迴圈:
CREATE PROCEDURE doiterate(p1 INT)
BEGIN
label1: LOOP
SET p1 = p1 + 1;
IF p1 < 10 THEN ITERATE label1; END IF;
LEAVE label1;
END LOOP label1;
END;區塊標籤的範圍不包含在區塊內宣告之處理常式的程式碼。詳細資訊,請參閱第 15.6.7.2 節,「DECLARE ... HANDLER 陳述式」。