PL/SQL有四种类型的循环:简单循环、WHILE循环、FOR循环以及游标FOR循环。在这里我们主要讨论前三种,除此之外,还将讨论Oracle 11g中新引入的CONTINUE语句。

一、 简单循环

LOOP
             STATEMENT 1;
             STATEMENT 2;
             ...
             STATEMENT N;
        END LOOP;

上述语句会无限制执行,因为没有语句指定何时可以终止循环。因此,简单循环称为无限循环。

一般循环会有退出条件。退出条件有两种形式:EXIT 和 EXIT WHEN。l两者是等价的。语法分别如下:

LOOP                                               LOOP 
              STATEMENT 1;                                  STATEMENT 1;
              STATEMENT 2;                                  STATEMENT 2;
              IF   CONDITION  THEN                        EXIT WHEN CONDITION;
                    EXIT;                                   END LOOP;
              END IF;
         END LOOP;

如下所示:

  1. DECLARE
  2. v_counter BINARY_INTEGER := 0;
  3. BEGIN
  4. LOOP
  5. v_counter := v_counter+1;
  6. DBMS_OUTPUT.PUT_LINE('v_counter = '||v_counter);
  7. IF v_counter = 5 THEN -->> EXIT语句
  8. EXIT;
  9. END IF;
  10. END LOOP;
  11. END;
  1. DECLARE
  2. v_counter BINARY_INTEGER := 0;
  3. BEGIN
  4. LOOP
  5. v_counter := v_counter+1;
  6. DBMS_OUTPUT.PUT_LINE('v_counter = '||v_counter);
  7. EXIT WHEN v_counter = 5; -->> EXIT WHEN语句
  8. END LOOP;
  9. END;

二、 WHILE循环

WHILE循环的结构如下所示:

WHILE CONDITION LOOP
              STATEMENT 1;
              STATEMNET 2;
              ...
              STATEMENT N;
        END LOOP;

上例简单循环的例子可改写如下:

  1. DECLARE
  2. v_counter BINARY_INTEGER := 0;
  3. BEGIN
  4. WHILE v_counter < 5 LOOP
  5. v_counter := v_counter+1;
  6. DBMS_OUTPUT.PUT_LINE('v_counter = '||v_counter);
  7. END LOOP;
  8. END;

在WHILE循环体中,同样可以使用EXIT和EXIT WHEN语句以提前终止循环

三、 整型值FOR循环

其结构如下:

FOR loop_counter IN [REVERSE] lower_limit..upper_limit LOOP
             STATEMENT 1;
             STATEMENT 2;
             ...
             STATEMENT N;
       END LOOP;

变量loop_counter是隐含定义的索引变量。不需要在PL/SQL语句块的声明部分定义循环计数器。这个变量时循环结构定义的。lower_limit和upper_limit是两个整数数字或者在运行时计算结果为整数值的表达式,双点号(..)是范围操作符。如果使用IN REVERSE,则循环计数器会从upper_limit到lower_limit。

上例简单循环的例子可改写如下:

  1. BEGIN
  2. FOR v_counter IN 1..5 LOOP
  3. DBMS_OUTPUT.PUT_LINE('v_counter = '||v_counter);
  4. END LOOP;
  5. END;

上述讨论的EXIT和EXIT WHEN语句也可以在FOR循环的循环体中使用。

四、 CONTINUE语句

CONTINUE语句有两种形式:CONTINUE和CONTINUE WHEN

CONTINUE语法如下:

IF CONTINUE_CONDITION THEN
           CONTINUE;
       END IF;

CONTINUE WHEN语法如下:

CONTINUE WHEN CONTINUE_CONDITION;

二者等效。

举例如下,求1到10内偶数的乘积。

  1. DECLARE
  2. v_sum number := 1;
  3. BEGIN
  4. FOR i IN 1..10 LOOP
  5. IF MOD(i,2) != 0 THEN
  6. CONTINUE;
  7. END IF;
  8. v_sum := v_sum*i;
  9. END LOOP;
  10. DBMS_OUTPUT.PUT_LINE('The number is = '||v_sum);
  11. END;

五、嵌套循环

我们已经讨论过三种类型的循环:简单循环、WHILE循环以及FOR循环。任何一种循环都可以嵌套在其他循环中。

试举一例:

  1. DECLARE
  2. v_counter1 INTEGER :=0;
  3. v_counter2 INTEGER;
  4. BEGIN
  5. WHILE v_counter1 < 3 LOOP
  6. DBMS_OUTPUT.PUT_LINE('v_counter1: '||v_counter1);
  7. v_counter2 := 0;
  8. LOOP
  9. DBMS_OUTPUT.PUT_LINE('v_counter2: '||v_counter2);
  10. v_counter2 := v_counter2+1;
  11. EXIT WHEN v_counter2 >= 2;
  12. END LOOP;
  13. v_counter1 := v_counter1+1;
  14. END LOOP;
  15. END;

 六、循环标签

循环标签出现在循环的开始处,在循环语句的结尾处使用。在嵌套循环中,循环标签很有必要,因为这会大大提升代码的可读性。

在某些场合,必须使用循环标签,如下例所示:

  1. BEGIN
  2. <<outer>>
  3. FOR v_counter IN 1..3 LOOP
  4. <<inner>>
  5. FOR v_counter IN 1..2 LOOP
  6. DBMS_OUTPUT.PUT_LINE('outer.v_counter '||outer.v_counter);
  7. DBMS_OUTPUT.PUT_LINE('inner.v_counter '||inner.v_counter);
  8. END LOOP inner;
  9. END LOOP outer;
  10. END;

在这里我们用了循环标签,因为内、外部循环都使用了相同的循环计数器v_counter。为了引用v_counter的内部直和外部值,就要使用循环标签。当然,循环标签的名称可任意取。

Oracle循环语句的更多相关文章

  1. oracle 循环语句

    1.基本循环(至少会执行一次) DECLARE I ; BEGIN LOOP --循环开始 DBMS_OUTPUT.PUT_LINE('VALUE:'||I); ; --退出循环条件: I:; --循 ...

  2. 在存储过程中执行3种oracle循环语句

    create or replace procedure pr_zhaozhenlong_loop /* 名称:在存储过程中执行3种循环语句 功能:利用循环给表中插入数据 调用: begin -- Ca ...

  3. MySQL与Oracle 差异比较之四条件循环语句

    循环语句 编号 类别 ORACLE MYSQL 注释 1 IF语句使用不同 IF iv_weekly_day = 'MON' THEN       ii_weekly_day := 'MON';ELS ...

  4. oracle学习--循环语句

    oracle学习--循环语句  loop循环: create or replace procedure pro_test_loop is i number; begin i:=0; loop i:=i ...

  5. Oracle使用语句块之循环插入数据

    1.业务要求:  将oracle表A的整表的数据一次性导入到表B中 , 以A_ID为外键关联. (*******如果开发环境和实际生产环境的数据一致,而且数据量比较小情况,可以直接手动添加数据; ** ...

  6. oracle的控制语句if和循环语句loop while for

    pl/sql的控制结构if-then if-then-else if-then-elsif-else 案例1:编写一个过程,可以输入一个雇员名,如果该雇员的工资低于2000,就给该雇员工资增加10% ...

  7. Oracle中PL/SQL的循环语句

    在PL/SQL中可以使用LOOP语句对数据进行循环处理,利用该语句可以循环执行指定的语句序列.常用的LOOP循环语句包含3种形式:基本的LOOP.WHILE...LOOP和FOR...LOOP. LO ...

  8. Oracle 数据库语句大全

    Oracle数据库语句大全 ORACLE支持五种类型的完整性约束 NOT NULL (非空)--防止NULL值进入指定的列,在单列基础上定义,默认情况下,ORACLE允许在任何列中有NULL值. CH ...

  9. HTML基础--JS简介、基本语法、类型转换、变量、运算符、分支语句、循环语句、数组、函数、函数调用.avi

    JS简介 1.JavaScript是个什么东西? 它是个脚本语言,需要有宿主文件,它的宿主文件是HTML文件. 2.它与Java什么关系? 没有什么直接的联系,Java是Sun公司(已被Oracle收 ...

随机推荐

  1. [原] XAF 添加日期筛选下拉选择

    1.ListView 添加日期筛选下拉选择,选择指定,可指定日期范围 2.Code using DevExpress.Data.Filtering; using DevExpress.ExpressA ...

  2. Erlang在Windows上开发环境搭建全过程讲解目录

    我会按照下面的列表来一步一步讲解,在windows来开发Erlang所用到的一些工具,和知识.我会不停的添加和修正. Erlang运行时环境 Erlang开发工具选择 Rebar来构建,编译,测试,发 ...

  3. Eclipse - Failed to load the JNI shared Library (JDK)

    When I try opening Eclipse, a pop-up dialog states: Failed to load the JNI shared library "C:/J ...

  4. QQ分组显示列表ExpandableListView组件应用源码

    ExpandableListView又称为可扩展的ListView组件,他和ListView组件很相似 不过每行的显示有两个xml文件,一个xml文件用于定义分组列表的显示风格, 还有一个xml文件用 ...

  5. Flask的socket.error:10053

    一脸懵逼: 学习python一段时间,最近使用flask搭建了一个服务器,然后使用phantom(相当于浏览器)发送请求发送了几条flask就挂掉了,报错信息如下: 由于个人python经验不是很足, ...

  6. 跟visual studio 集成的git插件

    目前有三个,git extension,微软的 visual studio tools for git extension,还有git source control provider 经测试,最好用的 ...

  7. ng2-timesheet, 一个timesheet.js的angular2复制版

    一个 timesheet.js (JavaScript library for HTML5 & CSS3 time sheets) 的 Angular 2 复制版 用法: npm instal ...

  8. Attic 0.8.1 发布,备份程序

    Attic 0.8.1 修复了昨天刚发布的 Attic 0.8 的一个段错误. Attic 是一个可以保证文件不重复的备份程序.Attic 的主要目标是提供一个高效和安全的方法来备份数据.重复数据删除 ...

  9. Eclipse引入外部Jar在发布时没有自动带入,导致出现ClassNoFound错误

    今天换了一台电脑重新配置环境调试老程序的时候出现链接数据库错误java.lang.ClassNotFoundException: oracle.jdbc.driver.OracleDriver提示. ...

  10. 算法:POJ1006 三重峰值问题

    这题有直接套公式的解法 这里提供一个O(n)的解法. package practice; import java.io.BufferedInputStream; import java.util.Sc ...