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 把它们打印出来
总结 :
- 实验时把set serveroutput on 打开
- 以上的例子的目的主要是为了提高性能. 这里的性能主要指的是速度 .
- 速度指的是批量插入, 更新 , 删除 , 为什么会提高速度呢 ? 提取到的数据都在内存中进行处理, 因为在内存处理比较快 , 这是常识 .
以上所述是小编给大家介绍的Oracle批量查询、删除、更新使用BULK COLLECT提高效率,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
- Oracle批量插入数据的三种方式【推荐】
- C# Oracle批量插入数据进度条的实现代码
- Oracle + Mybatis实现批量插入、更新和删除示例代码
- MyBatis批量插入数据到Oracle数据库中的两种方式(实例代码)
- Oracle两张表关联批量更新其中一张表的数据
- mybatis执行批量更新batch update 的方法(oracle,mysql两种)
- Oracle批量导入文本文件快速的方法(sqlldr实现)
- Oracle+Mybatis的foreach insert批量插入报错的快速解决办法
- Java实现mybatis批量插入数据到Oracle
- Oracle批量执行sql语句之禁用所有表的外键
- oracle+mybatis 使用动态Sql当插入字段不确定的情况下实现批量insert
- Oracle 高速批量数据加载工具sql*loader使用说明
- Oracle数据库更新大批量数据案例
相关文章
oracle连接数据库报错ORA-12170:TNS连接超时解决办法
这篇文章主要给大家介绍了关于oracle连接数据库报错ORA-12170:TNS连接超时的解决办法,ORA-12170是Oracle数据库连接错误,表示数据库连接超时,文中通过图文介绍的非常详细,需要的朋友可以参考下2024-01-01Windows下编写批处理脚本来启动和重置Oracle数据库
这篇文章主要介绍了Windows下编写cmd脚本来对Oracle数据库执行启动和重置的方法,只需在bat文件中保存cmd shell之后就可以双击使用,简单粗暴,需要的朋友可以参考下2016-03-03Navicat连接Oracle数据库报错:Oracle library is not&nb
这篇文章主要介绍了解决Navicat连接Oracle数据库提示oracle library is not loaded的问题,本文通过图文结合的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2024-06-06Oracle针对数据库某一行进行操作的时候,如何将这一行加行锁
Oracle针对数据库某一行进行操作的时候,如何将这一行加行锁的实现方法2009-02-02
最新评论