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

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;   

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值