使用循环应考虑的因素

1. 循环什么时候结束

2. 什么时候测试是否该结束循环

3. 采用这种循环的原因

1. 普通循环(简单循环)

使用场合, 不能确定循环执行多少次, 要求循环至少执行一次.

另外, 退出循环时, 可以使用如下两种方式:

EXIT;  // 直接退出

EXIT WHEN condition  // 有条件退出

2. for 循环

使用场合,只有有限次数循环, 又不想过早的退出循环.

使用循环规则:

  • 不要声明循环索引, 例如下例中的 l_current_year, plsql会自动的用一个integer类型的局部变量作为循环索引》
  • 在范围部分使用表达式(包括下边界和上边界)会在循环开始时被求值一次, 范围部分不会随着循环的反复执行被重复求值,如果在循环体内部改变了范围表达式使用的变量, 这种改变对范围边界没有任何作用
  • 在循环体内部不要改变索引值或者范围边界值, 这是非常不好的编程习惯.
  • 使用 reverse 关键字可以迫使循环从上边界到下边界递减式进行, 你必须确保范围是 (lowest number .. highest number) 这个顺序不能颠倒

如果你想处理非平滑增长的 for 循环, 例如步长是2, 那么你就要在循环体内判断, 而不是改变循环索引的值, 例如你可以判断偶数时执行, 这样, 就跟步长是 2 是一个效果.

3. while 循环

使用场合, 事先无法知道循环多少次, 想通过条件来终止循环, 循环体不是必须要执行.

与普通循环的区别是, 普通循环至少要执行一次循环体.

4. 游标型 for 循环

基本用法是 for record in {cursor_name | (explicit select statement)}

loop

executable statement(s)

end loop;

使用这种循环的原因, 类似 linux 中的 awk. 当要依次取出一个游标中的每一行记录并处理时, 也可能是分析每条记录的某个字段, 此时, 就使用游标for循环.

循环中可以使用标签 <<>>

可以使用标签来指定变量是在那层循环.

11g 以后可以使用 continue 语句

循环尽量做到 “one way in, one way out”

pl/sql programming 05 循环迭代处理的更多相关文章

  1. Oracle PL/SQL中的循环处理(sql for循环)

    今天来说下Oracle中的循环迭代处理,因为从自己的博客统计中看到,不少网友都搜索了关键字"SQL FOR循环",所以打算在这里说下个人的理解. PL/SQL也和我们常用的编程语言 ...

  2. Oracle PL/SQL之LOOP循环控制语句

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

  3. pl/sql programming 03 语言基础

    PL/SQL 块结构 最小的有意义的代码单元叫做 块(block). 一个块是一组代码, 这个块给出了执行边界, 也为变量声明和异常处理提供了作用范围, pl/sql 准许我们创建匿名块和命名块, 命 ...

  4. PL/SQL中LOOP循环控制语句

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

  5. [转载]Oracle PL/SQL之LOOP循环控制语句

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

  6. pl/sql programming 15 数据提取

    数据提取 -- 游标 游标只是一个指向某个结果集的指针. 声明游标: cursor employee_cur IS select * from employees; 打开游标: open employ ...

  7. pl/sql programming 06 异常处理

    如果 PLSQL发生了错误, 无论是系统错误还是应用错误, 都会抛出一个异常, 当前 PL/SQL 块中执行单元会暂停处理, 如果当前块有一个异常处理单元的话, 控制会转移到当前块的异常处理单元来处理 ...

  8. pl/sql programming 02 创建并运行plsql代码

    /* * chap 02 * ------------------------------------------------- */ create or replace function wordc ...

  9. oracle pl/sql中的循环及if语句

    for循环 /* for循环打印1到10 */ set serveroutput on; declare begin .. loop dbms_output.put_line(i); end loop ...

随机推荐

  1. 使用开关、分段控件和web视图

    #import "XViewController.h" @interface XViewController () @end @implementation XViewContro ...

  2. Java读取图片并修改像素,创建图片

    public void replaceImageColor(String file, Color srcColor, Color targetColor) throws IOException{ UR ...

  3. PE文件结构

    PE头 typedef struct _IMAGE_NT_HEADERS { DWORD Signature; PE头标识 为固定的ascii码 PE\\ IMAGE_FILE_HEADER File ...

  4. 17+个ASP.NET MVC扩展点,含源码{转}

    1.自定义一个HttpModule,并将其中的方法添加到HttpApplication相应的事件中!即:创建一个实现了IHttpmodule接口的类,并将配置WebConfig.在自定义的HttpMo ...

  5. Linux系统下利用wget命令把整站下载做镜像网站

    Linux系统下利用wget命令把整站下载做镜像网站 2011-05-28 18:13:01 | 1次阅读 | 评论:0 条 | itokit  在linux下完整的用wget命令整站采集网站做镜像 ...

  6. PHP7安装笔记

    PHP7安装笔记 时间 -- :: 喵了个咪 原文 http://www.hdj.me/php7-install-note 主题 PHP # 安装mcrypt yum install -y php-m ...

  7. 解决Notice错误,性能竟然提升了1000多倍!

    先说PHP的deprecated错误的性能问题 最近刚刚完成了一个项目,在测试完基本功能后,我们就发布到线上.结果上线不久就发现产生了大量的错误,如下图: 一看都是PHP的Deprecated错误,是 ...

  8. 控制台应用程序的Main方法

    总结一下Main方法规则: 1.Main 方法名大小写有规范. 2.Main 方法返回类型只有 void.int两种返回类型. 3.Main 方法的参数可以是string[] args,也可以为空,只 ...

  9. ExtJs之单选及多选框

    坚持 <!DOCTYPE html> <html> <head> <title>ExtJs</title> <meta http-eq ...

  10. C#日期大全

    DateTime dt = DateTime.Now; // Label1.Text = dt.ToString();//2005-11-5 13:21:25 // Label2.Text = dt. ...