ITPub博客

首页 > Linux操作系统 > Linux操作系统 > BLUK COLLECT

BLUK COLLECT

原创 Linux操作系统 作者:47328983 时间:2012-03-28 20:05:45 0 删除 编辑

1.使用FORALL比FOR效率高,因为前者只切换一次上下文,而后者将是在循环次数一样多个上下文间切换。

2.使用BLUK COLLECT一次取出一个数据集合,比用游标条取数据效率高,尤其是在网络不大好的情况下。但BLUK COLLECT需要大量内存。

使用例子:

(1)定义一个TABLE

CREATE OR REPLACE TYPE string_table AS TABLE OF VARCHAR2(100);

(2)在存储过程里面测试

DECLARE

v_table string_table;

BEGIN

SELECT cust_name

BULK COLLECT INTO v_table

FROM cust c

WHERE c.cust_id BETWEEN 64561 AND 64565;

FORALL idx IN 1..v_table.COUNT

INSERT INTO cust_test VALUES(v_table(idx));

COMMIT;

END;

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/241379/viewspace-719772/,如需转载,请注明出处,否则将追究法律责任。

下一篇: oracle 小结
请登录后发表评论 登录
全部评论

注册时间:2009-03-07

  • 博文量
    111
  • 访问量
    329019