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


猜你喜欢
- 单例模式是一种常见的设计模式,它在系统中仅允许创建一个实例来控制对某些资源的访问。在 Go 语言中,实现单例模式有多种方式,本篇文章将带你深
- 如果你的数据量有几十万条,用户又搜索一些很通俗的词,然后要依次读最后几页重温旧梦。mysql该很悲壮的不停操作硬盘。 所以,可以试着让mys
- 为什么我写ASP分页教程要提到AJAX呢,因为我们要多练习一下编程过程中,结构化的重要性. 再加上很多朋友对分页感到很高深,所以一直都不敢去
- 环境Win10Python3.6.6Django2.1.3中间件作用 中间件用于全局修改Django的输入或输出。中间件常见用途 缓存会话认
- 版本链在InnoDB引擎表中,他们的聚簇索引记录中有两个隐藏列:trx_id:用来存储对数据进行修改时的事务idroll_pointer:每
- 抛出一个问题,其实所谓的熟悉原生JS,怎样的程度才是熟悉呢?最近都在做原生JS熟悉的练习。。。用原生Js封装了一个Ajax插件,引入一般的项
- 本文实例讲述了python输出指定月份日历的方法。分享给大家供大家参考。具体实现方法如下:#!/usr/bin/pythonimport c
- 项目场景:在使用selenium模块进行数据爬取时,通常会遇到爬取iframe中的内容。会因为定位的作用域问题爬取不到数据。问题描述:我们以
- 一、前言Python提供两种方法进行字符串格式化1、利用百分号来格式化字符串,现在Python已停止更新这种方法2、字符串的format方法
- 本文实例讲述了python计算N天之后日期的方法。分享给大家供大家参考。具体如下:python计算N天之后的日期,可以自己写成一个函数,想得
- 原因: __str__()这个特殊方法将对象转换为字符串的结果效果图:代码:# 定义一个Person类class Person(o
- 一、计数排序计数排序(Counting sort)是一种稳定的排序算法算法的步骤如下:找出待排序的数组中最大和最小的元素统计数组中每个值为i
- tuple函数功能和list功能很相似,以序列为参数并把它转换为元组>>> tuple([1,2,3])(1, 2, 3)
- 简单了解多子图学习matplotlib的时候,有人肯定会觉得为啥不用Excel,为啥不用origin,为啥不直接使用软件,其实matplot
- 前言在日常开发中,我们经常需要判断目标元素是否在视窗之内或者和视窗的距离小于一个值(例如 100 px),从而实现一些常用的功能,例如:图片
- 本文是对《Python Qt GUI快速编程》的第10章的例子剪贴板用Python3+PyQt5进行改写,分别对文本,图片和html文本的复
- 今天来和大家聊聊抽样的几种常用方法,以及在Python中是如何实现的。抽样是统计学、机器学习中非常重要,也是经常用到的方法,因为大多时候使用
- 背景node.js,有人称之为运行在服务器端的JavaScript。以往我们使用JavaScript时,都是依赖后端查询数据库并返回数据,而
- 你知道SQL Server这么庞大的企业级数据库服务器产品是如何build出来的吗?这有些相关的数据:每个build 的大小在300GB左右
- IE下专属CSS:<![if !IE]><link rel="stylesheet" type=&qu