退出嵌套的FOR LOOP循环(直接退出所有的循环)

推出嵌套的FOR LOOP循环,有两种方法,第一种,使用GOTO语句跳出循环,跳到指定的位置,这时候,需要使用LABLE标记符;

 1 DECLARE
2 V_COUNT NUMBER := 6;
3 BEGIN
4 FOR IDX1 IN 1 .. 5 LOOP
5 DBMS_OUTPUT.PUT_LINE('first---' || IDX1);
6 FOR IDX2 IN 1 .. 5 LOOP
7 DBMS_OUTPUT.PUT_LINE('secord---' || IDX2);
8 FOR IDX3 IN 1 .. 5 LOOP
9 IF IDX3 = 1 THEN
10 GOTO OUTER1;
11 END IF;
12 END LOOP;
13 EXIT WHEN IDX2 = 2;
14 END LOOP;
15 EXIT WHEN IDX1 = 2;
16 END LOOP;
17
18 <<OUTER1>>
19 DBMS_OUTPUT.PUT_LINE('---------------------------');
20 V_COUNT := 7;
21 DBMS_OUTPUT.PUT_LINE('v_count---' || V_COUNT);
22 END;

结果:

第二种方法,使用全局变量进行控制:

 1 DECLARE
2 V_FLAG BOOLEAN := TRUE;
3 BEGIN
4 FOR IDX1 IN 1 .. 5 LOOP
5 DBMS_OUTPUT.PUT_LINE('first---' || IDX1);
6 FOR IDX2 IN 1 .. 5 LOOP
7 DBMS_OUTPUT.PUT_LINE('secord---' || IDX2);
8 FOR IDX3 IN 1 .. 5 LOOP
9 IF IDX3 = 1 THEN
10 V_FLAG := FALSE;
11 DBMS_OUTPUT.PUT_LINE('third---' || IDX2);
12 EXIT;
13 END IF;
14 END LOOP;
15 EXIT WHEN V_FLAG = FALSE;
16 END LOOP;
17 EXIT WHEN V_FLAG = FALSE;
18 END LOOP;
19 DBMS_OUTPUT.PUT_LINE('---------------------------');
20 DBMS_OUTPUT.PUT_LINE('exit');
21 END;

运行结果:

 

转载于:https://www.cnblogs.com/caroline/archive/2012/03/26/2418515.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值