Oracle 中的GOTO,RETURN,EXIT

本文详细介绍了PL/SQL中的流程控制语句GOTO、RETURN、EXIT的使用方法及区别,并通过示例展示了如何利用自定义异常实现JAVA中continue的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.GOTO,主要用于跳转,但会打乱我们的程序逻辑,一般不使用,它可以实现RETURN,EXIT的功能

2.RETURN,返回程序末尾,结束程序

3.EXIT,主要用于退出当前循环,相当于java中的break.

4.要实现java中continue的功能可以使用自定义异常的方式

它们之间的比较:

--这里的GOTO相当于下面的EXIT用法
BEGIN
   FOR i IN 1..2 LOOP
      IF i=2 THEN
         GOTO label;
      END IF;
      dbms_output.put_line('i='||i);
      
   END LOOP;
   <<label>>
   dbms_output.put_line('the last...');
END;
/
i=1
the last...
PL/SQL procedure successfully completed.
BEGIN
   FOR i IN 1..2 LOOP
      IF i=2 THEN
         --GOTO label;
         EXIT;
      END IF;
      dbms_output.put_line('i='||i);
      
   END LOOP;
   <<label>>
   dbms_output.put_line('the last...');
END;
/
i=1
the last...
PL/SQL procedure successfully completed.
BEGIN
   FOR i IN 1..2 LOOP
      IF i=2 THEN
         --GOTO label;
         --EXIT;
         RETURN;
      END IF;
      dbms_output.put_line('i='||i);
   END LOOP;
   <<label>>
   dbms_output.put_line('the last...');
END;
/
i=1
PL/SQL procedure successfully completed.
--下面相当于上面的RETURN
BEGIN
   FOR i IN 1..2 LOOP
      IF i=2 THEN
         GOTO label;
         --EXIT;
         --RETURN;
      END IF;
      dbms_output.put_line('i='||i);
   END LOOP;
   dbms_output.put_line('the last...');
   <<label>>
   NULL;--这个NULL不能省略,<<label>>不能在END;END LOOP;等之前
END;
/
i=1
PL/SQL procedure successfully completed.

自定义异常的方式实现continue的功能

DECLARE
  e_My_Exception EXCEPTION;
  --PRAGMA EXCEPTION_INIT (e_My_Exception, -1401);
BEGIN
   FOR i IN 1..2 LOOP
   BEGIN
      IF i=2 THEN
         RAISE e_My_Exception;
      END IF;
      dbms_output.put_line('i='||i);
      EXCEPTION
          WHEN e_My_Exception THEN
             NULL;
   END;
   END LOOP;
   dbms_output.put_line('the last...');
END;
/

 

转载于:https://www.cnblogs.com/lynnwang/p/4398592.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值