转Oracle 中的GOTO,RETURN,EXIT
来源:互联网 发布:炒股书籍推荐 知乎 编辑:程序博客网 时间:2024/06/04 18:36
1.GOTO,主要用于跳转,但会打乱我们的程序逻辑,一般不使用,它可以实现RETURN,EXIT的功能
2.RETURN,返回程序末尾,结束程序
3.EXIT,主要用于退出当前循环,相当于java中的break.
4.要实现java中continue的功能可以使用自定义异常的方式
它们之间的比较
5 null 每个块必须要有语句
如果什么都不写,就写个null,使编译通过
--这里的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;
/
本篇文章来源于 Linux公社网站(www.linuxidc.com) 原文链接:http://www.linuxidc.com/Linux/2011-04/34479.htm
- 转Oracle 中的GOTO,RETURN,EXIT
- Oracle 中的GOTO,RETURN,EXIT
- Oracle 中的GOTO,RETURN,EXIT
- Oracle循环中的EXIT、RETURN、CONTINUE解密
- FORTRAN 中的goto/exit/cycle
- oracle 存储过程循环体中的return和exit区别:
- Oracle 顺序控制GOTO语句(exit,continue)
- C# 中的 break ,goto ,contitue ,return 语句
- C语言中的return ,exit
- ORACLE数据库中的RETURN与EXIT在循环中使用小议
- Oracle 中Return 和exit的区别
- Oracle中Exit与Return用法
- Exit 与 Goto :eof 在批处理中的区别
- Exit 与 Goto :eof 在批处理中的区别
- Exit 与 Goto :eof 在批处理中的区别
- PL/SQL 程序包中的EXIT和RETURN
- C语言中的return,exit,break,continue
- C语言中的return,exit,break,continue
- jQuery事件
- poj 2728(迭代+prime)
- EditText属性大全
- 傅老师课堂:最大子序列
- TextView属性大全
- 转Oracle 中的GOTO,RETURN,EXIT
- SQLSERVER 日志清理(转贴)
- RFS的web自动化验收测试——介绍篇
- Highcharts常用属性的说明
- Autosize 2 (恒屏和自动旋转)
- xcode的卸载
- 国内cPanel空间试用手记
- Linux服务器运维命令整理
- 傅老师课堂:红黑树