源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2021-12-28 15:22 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Oracle批量查询、删除、更新使用BULK COLLECT提高效率
BULK COLLECT(成批聚合类型)和数组集合type类型is table of 表%rowtype index by binary_integer用法笔记。 例1: 批量查询项目资金账户号为 "320001054663"的房屋账户信息并把它们打印出来 .
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"的房屋账户的余额。
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  把它们打印出来 [b]总结 : [/b] [list] [*]实验时把set serveroutput on  打开[/*] [*]以上的例子的目的主要是为了提高性能. 这里的性能主要指的是速度  .[/*] [*]速度指的是批量插入, 更新 , 删除  , 为什么会提高速度呢 ?  提取到的数据都在内存中进行处理, 因为在内存处理比较快 , 这是常识 .[/*] [/list] 以上所述是小编给大家介绍的Oracle批量查询、删除、更新使用BULK COLLECT提高效率,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程素材网网站的支持!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部