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

作者:回憶′亂人心 时间:2023-07-14 03:15:52 

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  把它们打印出来

总结 :

  • 实验时把set serveroutput on  打开

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

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

以上所述是小编给大家介绍的Oracle批量查询、删除、更新使用BULK COLLECT提高效率,希望对大家有所帮助

来源:http://www.cnblogs.com/beyondzw/archive/2017/04/28/6781656.html

标签:oracle,查询,删除,更新,bulk,collect
0
投稿

猜你喜欢

  • Python实战之手写一个搜索引擎

    2023-07-11 21:16:49
  • 修改并编译golang源码的操作步骤

    2024-05-02 16:26:23
  • 基于python分享一款地理数据可视化神器keplergl

    2023-09-27 20:54:05
  • MySQL中一些鲜为人知的排序方式

    2024-01-18 03:18:12
  • Python装饰器的两种使用心得

    2023-03-17 17:03:23
  • PHP生成网站桌面快捷方式代码分享

    2023-06-16 02:54:17
  • OpenCV-Python实现腐蚀与膨胀的实例

    2023-06-05 18:07:07
  • 详解OpenCV中简单的鼠标事件处理

    2023-01-04 12:16:01
  • Google中秋logo被恶搞

    2007-09-25 15:55:00
  • python2.7 mayavi 安装图文教程(推荐)

    2022-05-12 05:39:13
  • javascript中的后退和刷新实现方法

    2023-08-23 09:36:45
  • python 使用pygame工具包实现贪吃蛇游戏(多彩版)

    2021-05-10 17:29:19
  • 解决pyinstaller打包exe文件出现命令窗口一闪而过的问题

    2021-09-28 01:03:45
  • Oracle 游标使用总结

    2009-10-02 17:36:00
  • Python drop方法删除列之inplace参数实例

    2023-07-23 23:26:49
  • Python中JSON的使用方法(超详细)

    2023-11-15 23:04:19
  • Python爬虫教程知识点总结

    2023-10-01 15:27:16
  • 分发服务器 系统抛出18483错误,未能连接服务器,因为'distributor_admin'未定义远程登陆

    2024-01-24 00:39:48
  • Go语言从单体服务到微服务设计方案详解

    2023-09-02 02:45:57
  • python实现堆排序的实例讲解

    2023-01-06 20:50:38
  • asp之家 网络编程 m.aspxhome.com