您的位置:首页 > 数据库

pl/sql中的几种循环控制结构

2010-09-16 13:18 459 查看
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;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: