oracle批量查询更新,Oracle批量查询、删除、更新使用BULK COLLECT提高效率

BULK COLLECT(成批聚合类型)和数组集合type类型is table of 表%rowtype index by binary_integer用法笔记。

例1: 批量查询项目资金账户号为 "320001054663"的房屋账户信息并把它们打印出来 .

sql;">

DECLARE

TYPE acct_table_type IS TABLE OF my_acct%ROWTYPE INDEX BY BINARY_INTEGER;

v_acct_table acct_table_type;

BEGIN

SELECT * BULK COLLECT INTO v_acct_table FROM my_acct WHERE parent_fund='320001054663';

FOR i IN 1..v_acct_table.COUNT LOOP

---循环打印

dbms_output.put_line('ACCT:'||v_acct_table(i).fund|| ','||v_acct_table(i).bal||','||v_acct_table(i).real_nmbr);

END LOOP;

END;

说明部分:

1. DECLARE 说明以下你要声明的部分

2. Type 声明是类型acct_table_typ e 类型的名字

3. IS TABLE OF 指定是一个集合的表的数组类型,简单的来说就是一个可以存储一列多行的数据类型,my_acct指出在哪个表上( 存在的表 ) %ROWTYPE 指在表上的行的数据类型.

4. INDEX BY BINARY_INTEGER 指索引组织类型

5. v_acct_table 定义一个变量来存储集合数据类型

6. BULK COLLECT INTO 指是一个成批聚合类型,简单的来说,它可以存储一个多行多列存储类型,into 后面指定从哪里来,

7. v_acct_table.COUNT 用来 v_acct_table 里面的数量

8. (i)表示下标号

例2: 批量更新项目资金账户号为 "320001054663"的房屋账户的余额。

sql;">

DECLARE

TYPE fund_table_type IS TABLE OF acct.fund%TYPE;

TYPE bal_table_type IS TABLE OF acct.bal%TYPE;

v_fund_table fund_table_type;

v_bal_table bal_table_type;

BEGIN

UPDATE acct SET bal=bal*1000 WHERE parent_fund='320001054663' RETURNING fund,bal BULK COLLECT INTO v_fund_table,v_bal_table;

FOR i IN 1..v_fund_table.COUNT LOOP

dbms_output.put_line('ACCT:'||v_fund_table(i)||','||v_bal_table(i));

END LOOP;

END;

说明部分:

1. %TYPE和 acct.fund数据类型一样

v_fund_table fund_table_type;

2. v_bal_table bal_table_type; 定义变量来存储它们 .

3. RETURNING 用来指定要返回的部分,BULK COLLECT INTO 成批聚合类型

4. 用for 把它们打印出来

总结 :

实验时把set serveroutput on 打开

以上的例子的目的主要是为了提高性能. 这里的性能主要指的是速度 .

速度指的是批量插入,更新,删除,为什么会提高速度呢 ? 提取到的数据都在内存中进行处理,因为在内存处理比较快,这是常识 .

以上所述是小编给大家介绍的Oracle批量查询、删除、更新使用BULK COLLECT提高效率,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程之家网站的支持!

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值