科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道[Oralce]在PL/SQL中使用正确的循环控制

[Oralce]在PL/SQL中使用正确的循环控制

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

当你在 PL/SQL 中处理一个被索引的表时,很多情况下你不能确定表上是否存在索引,所以你不能使用最明显的 FOR 循环方式来循环表中的值。

作者:Builder.com 2007年6月20日

关键字: ORACLE

  • 评论
  • 分享微博
  • 分享邮件
本文译自Builder.com,未经许可请勿转载

当你在 PL/SQL 中处理一个被索引的表时,很多情况下你不能确定表上是否存在索引,所以你不能使用最明显的 FOR 循环方式来循环表中的值。例如:

Declare
    type my list_type is table of number index by pls_integer;
    mylist mylist_type;
begin
    -- start at 2, instead of 1
    mylist(2) := 2;
    mylist(3) := 3;
    -- skip 4 and 5
    mylist(6) := 6;
    for i in 1..mylist.count loop
        dbms_output.put_line(mylist(i));
    end loop;
end;
/

前面的代码将返回 ORA-01403 错误:由于缺少索引1,没有发现数据。

如果你尝试使用 .FIRST/.LAST 修正这个问题,那么你将自动地从第一个索引开始循环,直到到达最后一个索引,如下:

Declare
    type mylist_type is table of number index by pls_integer;
    mylist mylist_type;
begin
    mylist(2) := 2;
    mylist(3) := 3;
    mylist(5) := 6;
    for i in mylist.first .. mylist.last loop
        dbms_output.put_lin(mylist(i));
    end loop;
end;
/

然而,你依然得到一个 ORA-01403 错误:由于跳过值,没有发现数据。要进一步避免这种错误,你可以在访问索引前使用 EXISTS 方法测试它是否存在:

Declare
    type mylist_type is table of number index by pls_integer;
    mylist mylist_type;
begin
    mylist(2) := 2;
    mylist(3) := 3;
    mylist(6) := 6;
    for i in mylist.first..mylist.last loop
        if (mylist.exists(i)) then
            dbms_output.put_line(mylist(i));
        end if;
    end loop;
end;
/

或者,你可以通过.NEXT 属性使用常规的 LOOP 循环来迭代一个表上存在的索引——但是你必须声明循环计数器:

Declare
    type mylist_type is table of number index by pls_integer;
    mylist mylist_type;
    i pls_integer;
begin
    mylist(2) := 2;
    mylist(3) := 3;
    mylist(6) := 6;
    i := mylist.first;
    loop
        dbms_output.put_line(mylist(i));
        exit when i = mylist.last;
        i := mylist.next(i);
    end loop;
end;
/

当你不确定哪些值已经被删除或装载而导致缺少索引时,可以使用上面这两个有效的方法作为默认方法。但是对于使用 FORALL 语句的大量操作,这两种方法都不能正确运行,原因是 FORALL 语句并不是一个真正的循环,而且其语法只能带一个下加界,一个上边界和一个 SQL DML 语句。

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章