1.基本循环
以loop开始以end loop结束,为了避免死循环,必须使用exit或者exit when 语句。
CREATE TABLE temp(cola INT);
DECLARE
i INT:=1;
BEGIN
LOOP
INSERT INTO temp VALUES(i);
EXIT WHEN i=10;
i:=i+1;
END LOOP;
END;
2.while循环
以while loop开始,以end loop;结束
DECLARE
i INT:=1;
BEGIN
WHILE i<=10 LOOP
INSERT INTO temp VALUES(i);
i:=i+1;
END LOOP;
END;
3.for循环 语法
for counter in [reverse]
lower_bound..upper_bound Loop
statement1;
statement2;
..........
end loop;
默认情况下,当使用for循环时,每次变量自动加1,如果指定reverse选项,那么循环控制变量会自动
减1.
BEGIN
FOR i IN REVERSE 1..10 LOOP
INSERT INTO temp VALUES(i);
END LOOP;
END;
4.嵌套循环和标号
嵌套循环需要标号(label)可以用<<label_name>>定义标号。
DECLARE
RESULT1 INT;
BEGIN
<<outerr>>
FOR i IN 1..100 LOOP
<<inter>>
FOR j IN 1..100 LOOP
RESULT1:=i*j;
EXIT outerr WHEN RESULT1=1000;
EXIT WHEN RESULT1=500;
END LOOP inter;
dbms_output.put_line(RESULT1);
END LOOP outerr;
dbms_output.put_line(RESULT1);
END;