编写循环控制结构时,用户可以使用基本循环,WHILE循环和FOR循环等三种类型的循环语句,下面分别介绍使用这三种循环

语句的方法。

1.基本循环
下面我来举基本循环的2个例子哈
declare  
  i integer; 
begin 
  i:=0; 
  LOOP 
  Exit When(i>5); 
       Dbms_Output.put_line(i); 
       i:=i+1; 
  END LOOP; 
end; 
/
0
1
2
3
4
5

 

declare

i int:=1;
 begin
 loop
 insert into testloop values(i);
 exit when i=10;
 i:=i+1;
 end loop;
 commit;
 end;
  /
SQL> select * from testloop;

         A
----------
         1
         2
         3
         4
         5
         6
         7
         8
         9
        10

已选择10行。

当使用基本循环时,无论是否满足条件,语句至少会被执行一次,当condition为TRUE时,会退出循环,并执行END LOOP后的

相应操作。当编写基本循环时一定要包含EXIT语句,否则会陷入死循环。另外还应该定义循环控制变量,并且在循环体内修

改循环控制变量的值

 

2.WHILE循环
基本循环至少要执行一次循环体内的语句,而对于WHILE循环来说,只有条件为TRUE时,才会执行循环体内的语句。WHILE循

环以WHILE ...LOOP开始,以END LOOP结束。

WHILE condition LOOP

           statement1;

           statement2;

           .....

END LOOP;

declare  
  i integer; 
begin 
  i:=0; 
  while i<5 loop 
     i:=i+1; 
     dbms_output.put_line(i); 
  end loop; 
end;
/

 

 declare
  i int:=1;
  begin
   while i<=10 loop
  insert into testloop values(i);
    i:=i+1;
 end loop;
 end;
 /

当condition为TRUE时,执行循环体内的语句,而当condition为FALSE或NULL时,会退出循环,并执行END LOOP后的语句。当

使用WHILE循环时,应该定义循环控制变量,并在循环体内改变循环控制变量的值。

 

3.FOR循环
当使用基本循环或WHILE循环时,需要定义循环控制变量,并且循环控制变量不仅可以使用NUMBER类型,也可以使用其他数据

类型。当使用FOR循环时,ORACLE会隐含定义循环控制变量。

FOR counter in [REVERSE] lower_bound. .upper_bound LOOP

         statement1;

         statement2;

         .......

END LOOP;

declare  
  i integer; 
begin 
  i:=0; 
  for i in 1..5 loop 
      dbms_output.put_line(i); 
  end loop; 
end; 
/

 

declare  
  i integer; 
begin
 for i in reverse 1..10 loop
 insert into testloop values(i);
  end loop;
  end;
/
reverse --相反,倒叙

 

for游标循环
create or replace procedure proc_test_cursor is
userRow test%rowtype;
cursor userRows is
select * from test;
begin
for userRow in userRows loop
dbms_output.put_line(userRow.id||’,'||userRow.Name||’,'||userRows%rowcount);
end loop;
end proc_test_cursor;
counter是循环控制变量,并且该变量由oracle隐含定义,不需要显式定义。lower_bound和upper_bound分别对应于循环控制

变量的下界值和上界值,默认情况下,当使用FOR循环时,每次循环时循环控制变量会自动增1.如果指定REVERSE选项,那么

每次循环时循环控制变量会自动减1。

4.嵌套循环和标号
嵌套循环是指在一个循环语句之中嵌入另一个循环语句,而标号(label)则用于标记嵌套块或嵌套循环,通过在嵌套循环中

使用标号,可以区分内层循环和外层循环,并且可以在内层循环中直接退出外层循环,在编写时可以用<<label_name>>定义

标号。

declare
result int;
begin
<<outer>>
for i in 1..100 loop
<<inter>>
for j in 1..100 loop
result:=i*j;
exit outer when result=1000;
exit when result=500;
end loop inter;
dbms_output.put_line(result);
end loop outer;
dbms_output.put_line(result);
 end;
  /
当执行以上PL/SQL块时,如果result=1000,那么直接退出外层循环,而result=500时只会退出内层循环。
100
200
300
400
500
600
700
800
900
500
1100
1200
1300
1400
1500
1600
1700
1800
1900
500
2100
2200
2300
2400
500
2600
2700
2800
2900
3000
3100
3200
3300
3400
3500
3600
3700
3800
3900
1000

PL/SQL 过程已成功完成。