FOR loops were introduced in MariaDB 10.3.
Integer range FOR loop:
[begin_label:] FOR var_name IN [ REVERSE ] lower_bound .. upper_bound DO statement_list END FOR [ end_label ]
Explicit cursor FOR loop
[begin_label:] FOR record_name IN cursor_name [ ( cursor_actual_parameter_list)] DO statement_list END FOR [ end_label ]
Explicit cursor FOR loop (Oracle mode)
[begin_label:] FOR record_name IN cursor_name [ ( cursor_actual_parameter_list)] LOOP statement_list END LOOP [ end_label ]
Implicit cursor FOR loop
[begin_label:] FOR record_name IN ( select_statement ) DO statement_list END FOR [ end_label ]
FOR loops allow code to be executed a fixed number of times.
In an integer range FOR loop, MariaDB will compare the lower bound and upper bound values, and assign the lower bound value to a counter. If REVERSE is not specified, and the upper bound value is greater than or equal to the counter, the counter will be incremented and the statement will continue, after which the loop is entered again. If the upper bound value is greater than the counter, the loop will be exited.
If REVERSE is specified, the counter is decremented, and the upper bound value needs to be less than or equal for the loop to continue.
Intger range FOR loop:
CREATE TABLE t1 (a INT); DELIMITER // FOR i IN 1..3 DO INSERT INTO t1 VALUES (i); END FOR; // DELIMITER ; SELECT * FROM t1; +------+ | a | +------+ | 1 | | 2 | | 3 | +------+
REVERSE integer range FOR loop:
CREATE OR REPLACE TABLE t1 (a INT);
DELIMITER //
FOR i IN REVERSE 12..4
    DO
    INSERT INTO t1 VALUES (i);
END FOR;
//
Query OK, 9 rows affected (0.422 sec)
DELIMITER ;
SELECT * FROM t1;
+------+
| a    |
+------+
|   12 |
|   11 |
|   10 |
|    9 |
|    8 |
|    7 |
|    6 |
|    5 |
|    4 |
+------+
Explicit cursor in Oracle mode:
SET sql_mode=ORACLE;
CREATE OR REPLACE TABLE t1 (a INT, b VARCHAR(32));
INSERT INTO t1 VALUES (10,'b0');
INSERT INTO t1 VALUES (11,'b1');
INSERT INTO t1 VALUES (12,'b2');
DELIMITER //
CREATE OR REPLACE PROCEDURE p1(pa INT) AS 
  CURSOR cur(va INT) IS
    SELECT a, b FROM t1 WHERE a=va;
BEGIN
  FOR rec IN cur(pa)
  LOOP
    SELECT rec.a, rec.b;
  END LOOP;
END;
//
DELIMITER ;
CALL p1(10);
+-------+-------+
| rec.a | rec.b |
+-------+-------+
|    10 | b0    |
+-------+-------+
CALL p1(11);
+-------+-------+
| rec.a | rec.b |
+-------+-------+
|    11 | b1    |
+-------+-------+
CALL p1(12);
+-------+-------+
| rec.a | rec.b |
+-------+-------+
|    12 | b2    |
+-------+-------+
CALL p1(13);
Query OK, 0 rows affected (0.000 sec)
    © 2019 MariaDB
Licensed under the Creative Commons Attribution 3.0 Unported License and the GNU Free Documentation License.
    https://mariadb.com/kb/en/for/