gpt4 book ai didi

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

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 25 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章Oracle批量查询、删除、更新使用BULK COLLECT提高效率由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

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

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

?
1
2
3
4
5
6
7
8
9
10
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"的房屋账户的余额.

?
1
2
3
4
5
6
7
8
9
10
11
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提高效率的文章就讲到这里了,如果你想了解更多关于Oracle批量查询、删除、更新使用BULK COLLECT提高效率的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com