create table -- drop table tmp_20190706_220000-- truncate table tmp_20190706_220000 create table tmp_20190706_220000 ( id integer, name varchar(100), memo varchar(200)); 1234567891011plsql into 通常简单的写法如下 declare lv_id tmp_20190706_220000.id%type; lv_…
对于数据量较大的插入操作可采用此种方法操作,注意: limit减少内存占用,如果数据量较大一次性全部加载到内存中,对PGA来说压力太大,可采用limit的方法一次加载一定数量的数据,建议值通常为1000.使用limit时注意,循环的时候如果用while cursor_name%found loop,对于最后一次fetch的数据量不足设定值1000,%found条件就会不成立.示例使用v_oid_lst.count > 0作为判断条件. 在写plsql代码块,定义数值变量时,建议采用pls_int…
DECLARE TYPE rr IS REF CURSOR; TYPE r_emp IS RECORD( empno ), ename ), job ), mgr ), hiredate DATE, sal , ), comm , ), deptno )); TYPE t_e IS TABLE OF r_emp; e t_e; ee t_e:= t_e(); r rr; BEGIN OPEN r FOR SELECT * FROM apps.emp; LOOP EXIT WHEN r%notfo…
通过bulk collect减少loop处理的开销 采用bulk collect可以将查询结果一次性地加载到collections中. 而不是通过cursor一条一条地处理. 可以在select into,fetch into,returning into语句使用bulk collect. 注意在使用bulk collect时,所有的into变量都必须是collections. 举几个简单的例子: --在select into语句中使用bulk collect DECLARE TYPE SalL…
2014-10-04 Created By BaoXinjian…
Oracle为PL/SQL中的SQL相关功能提供了FORALL语句和BULK COLLECT子句,显著的增强了SQL相关功能.这两个语句一起被称作PL/SQL的批处理语句.Oracle为什么要提供这两个语句呢?我们首先了解一下PL/SQL的引擎.该引擎可以安装在数据库,或者应用开发工具上,例如Oracle Froms.当PL/SQL运行引擎执行一个代码块时,引擎本身只会处理过程语句,而SQL语句是发送给SQL引擎执行.SQL语句的执行时是由数据库的SQL引擎负责,再将执行结果返回给PL/SQL引…
概述 BULK COLLECT 子句会批量检索结果,即一次性将结果集绑定到一个集合变量中,并从SQL引擎发送到PL/SQL引擎.通常可以在SELECT INTO.FETCH INTO以及RETURNING INTO子句中使用BULK COLLECT. Oracle 使用 bulk collect 子句的用例 BULK COLLECT批量绑定 支持复合类型内部的集合类型 FETCH数据批量绑定 RETURNING 子句的批量绑定 不支持 INSERT returning 使用集合类型 动态SQL批…
Oracle数据库之FORALL与BULK COLLECT语句 我们再来看一下PL/SQL块的执行过程:当PL/SQL运行时引擎处理一块代码时,它使用PL/SQL引擎来执行过程化的代码,而将SQL语句发送给SQL引擎来执行:SQL引擎执行完毕后,将结果再返回给PL/SQL引擎.这种在PL/SQL引擎和SQL引擎之间的交互,称为上下文交换(context switch).每发生一次交换,就会带来一定的额外开销.下面是一个示意图: 从Oracle 8i开始,PL/SQL得到了两点增强,可以将PL/S…
通过bulk collect减少loop处理的开销,使用Bulk Collect提高Oracle查询效率 Oracle8i中首次引入了Bulk Collect特性,该特性可以让我们在PL/SQL中能使用批查询,批查询在某些情况下能显著提高查询效率. 采用bulk collect可以将查询结果一次性地加载到collections中. 而不是通过cursor一条一条地处理. 可以在select into,fetch into,returning into语句使用bulk collect. 注意在使用…
刚刚在inthirties老大的博客里看到这篇文章,写的不错,正好自己最近在学习PL/SQL,转过来学习学习. ================================================================================== bulk collect是可以看做是一种批获取的方式,在我们的plsql的代码段里经常作为into的扩展来使用.对于select id into v from .... 是一个常用的用法.不过这里只能是返回单条记录的时候,…
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; BEG…
https://orablogspot.blogspot.com/2014/09/ https://blogs.oracle.com/oraclemagazine/bulk-processing-with-bulk-collect-and-forall 该网站提供了bulk collect 和 forall 用法及案例…
我们知道PL/SQL程序中运行SQL语句是存在开销的,因为SQL语句是要提交给SQL引擎处理,这种在PL/SQL引擎和SQL引擎之间的控制转移叫做上下文却换,每次却换时,都有额外的开销.然而,FORALL和BULK COLLECT可以让PL/SQL引擎把多个上下文却换压缩成一个,这使得在PL/SQL中的要处理多行记录的SQL语句执行的花费时间骤降.       示例:一.BULK COLLECT将所得的结果集一次性绑定(全部) --下面的示例中使用了BULK COLLECT将得到的结果集绑定到记…
BULK COLLECT 子句会批量检索结果,即一次性将结果集绑定到一个集合变量中,并从SQL引擎发送到PL/SQL引擎.通常可以在SELECT INTO.FETCH INTO以及RETURNING INTO子句中使用BULK COLLECT.本文将逐一描述BULK COLLECT在这几种情形下的用法.    有关FORALL语句的用法请参考:批量SQL之 FORALL 语句 一.BULK COLLECT批量绑定的示例 [sql] view plaincopyprint? --下面的示例中使用了…
bulk collect 和 forall 联合应用写起来显得有些啰嗦,不过为了速度,多写两句又何妨 建立两个临时表 create table T_TEST ( TESTID NUMBER(19) not null, TESTNAME VARCHAR2(512), TESTTYPE VARCHAR2(512), TESTLEVEL VARCHAR2(512), ADDFLAG VARCHAR2(512) ); create table T_TEST2 ( TESTID NUMBER(19) no…
Bulk Collect特性可以让我们在PL/SQL中能使用批查询,批查询在某些情况下能显著提高查询效率. BULK COLLECT 子句会批量检索结果,即一次性将结果集绑定到一个集合变量中,并从SQL引擎发送到PL/SQL引擎. 可以在select into,fetch into,returning into语句使用bulk collect. 注意在使用bulk collect时,所有的into变量都必须是collections. 1. 背景 以前曾经做过一个需求,数据库中有两张表,A表是2千…
如果表结构只对应一个字段,可以 select col1 bulk collect into 变量,不用游标循环,简洁高效 create or replace function get_airway_subpoint(awid in number) return airway_subpnts_tab is --CREATE OR REPLACE TYPE AIRWAY_SUBPNTS_TAB  as table of number(11) v_ptns airway_subpnts_tab; --…
FORALL与BULK COLLECT的使用方法: 1.使用FORALL比FOR效率高,因为前者只切换一次上下文,而后者将是在循环次数一样多个上下文间切换. 2.使用BLUK COLLECT一次取出一个数据集合,比用游标条取数据效率高,尤其是在网络不大好的情况下.但BLUK COLLECT需要大量内存. 例子: create table test_forall ( user_id number(10), user_name varchar2(20)); select into 中使用bulk c…
BULK COLLECT 子句会批量检索结果,即一次性将结果集绑定到一个集合变量中,并从SQL引擎发送到PL/SQL引擎.通常可以在SELECT INTO.FETCH INTO以及RETURNING INTO子句中使用BULK COLLECT.本文将逐一描述BULK COLLECT在这几种情形下的用法. 一.BULK COLLECT批量绑定的示例 --下面的示例中使用了BULK COLLECT将得到的结果集绑定到记录变量中         DECLARE     TYPE emp_rec_typ…
我写东西一向追求短小精悍,就不放代码去验证的,只说结论,并会与Java泛型做对比.有不对之处还望指出. 泛型作为一个在C#2.0中就引入的特性,也是C#的重要特性之一,我经常看到有人讨论泛型带来的便捷性和(一定程度上的)安全性,却很少见有人说泛型的性能优势,要么点到即止要么泛泛而谈说得太复杂——可能仅仅是因为我孤陋寡闻吧…… 好了,废话不说了,以下是结论: 如果你要用一个ArrayList add一个byte,我们看看会发生什么. 假设在一个32位CLR上,对对象进行装箱要消耗8字节,用4字节存…
1.创建表对象的类型(oracle Types类目录下) create or replace type obj_table1 as object( xzq nvarchar2(19), mj number(38,8), gjzrd number(5), gjlyd number(5), gjjjd number(5)) 2.创建虚拟表 (oracle Types类目录下) create or replace type t_table1 is table of obj_table1 3.创建ora…
1.游标的含义 2.oracle 11g 中的三类游标的使用方式 3.oracle 11g中使用 fetch ... bulk collect into 进行批量.快速提取数据的方式 4.根据不同情况,选取不同的游标进行使用…
Bulk collect当没有数据抛出异常跟implicit cursor 处理不一样. 先看一下implicit cursor的处理吧: cl scr; DECLARE l_descr hardware.descr%type; BEGIN ; dbms_output.put_line('Item was found'); EXCEPTION WHEN no_data_found THEN dbms_output.put_line('Invalid item specified'); END;…
ORACLE数据库创建的时候,创建了一系列默认的用户和表空间 Oracle 10g 默认安装带来的用户名/密码 Username Password Description See Also CTXSYS CTXSYS The Oracle Text account Oracle Text Reference DBSNMP DBSNMP The account used by the Management Agent component of Oracle Enterprise Manager t…
WCF性能优势决定了其受欢迎程度,这些优势主要都体现在:统一性:互操作性:安全与可信赖:兼容性等方面. WCF是使用托管代码建立和运行面向服务(Service Oriented)应用程序的统一框架. WCF能够建立一个跨平台的安全.可信赖.事务性的解决方案, 且能与已有系统兼容协作. WCF是微软分布式应用程序开发的集大成者,它整合了.Net平台下所有的和分布式系统有关的技术,例如.Net Remoting.ASMX.WSE和MSMQ.以通信 (Communiation)范围而论,它可以跨进程.…
ToList<>()所带来的性能影响  前几天优化师弟写的代码,有一个地方给我留下很深刻的印象,就是我发现他总是将PLINQ的结果ToList<>(),然后再返回给主程序,对于这一点我十分不解,于是去问他是什么原因,得到的答案很幽默:因为习惯.    有时候对于方法的不甚了解加上“习惯”,往往是程序性能和稳定性终结者,就拿这个Case来说吧,原始代码如下: var query = from cr in LCRNormal.AsParallel()                  …
之前没有特别注意自动封装所带来的性能问题,今天看了effective java,实验了一下,结果大吃一惊: 考虑下面这段代码: public static void main(String args[]){ Long sum =0L; for(long i = 0;i < Integer.MAX_VALUE;i++){ sum+=i; } System.out.println(sum); } 运行这段代码我机器耗时是7000ms; 我们再看下面这段代码: public static void m…
memcache 与 redis 为web app 带来的性能提升 参考: 1. http://www.cnblogs.com/ToDoToTry/p/3513688.html…
wait/notify  机制是为了避免轮询带来的性能损失. 为了说清道理,我们用“图书馆借书”这个经典例子来作解释. 一本书同时只能借给一个人.现在有一本书,图书馆已经把这本书借了张三. 在简单的synchrnozed 同步机制下,李四如果想借,先要去图书馆查看书有没有还回来.李四是个心急的人,他每天都去图书馆查:而张三看书看得慢,过了半个月才把书还回来,结果李四在这半个月里全都白跑了,浪费了不少交通车费 而如果使用wait/notify机制,李四就不用白忙了.他第一次去图书馆时发现书已借走,…
Oracle数据库使用Analyze提升sql性能 如果你不使用analyze完成sql优化,将意味着:你拒绝使用数据库的查询优化器,也失去了使用优化连接的机会.假设你创建了一张拥有100万条记录的临时表,如果不对其进行分析,那么优化器将无法从现有的线索中获取表中真正的内容,于是它只能决定使用嵌套循环连接来一行行地扫描数据表,随着数据集的增长,你的数据库性能会越来越差. ORACLE数据库的PL/SQL语句执行的优化器,有基于代价的优化器(CBO)和基于规则的优化器(RBO). RBO的优化方式…