<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="es">
		<id>https://dosideas.com/wiki/index.php?action=history&amp;feed=atom&amp;title=Bulk_Collect</id>
		<title>Bulk Collect - Historial de revisiones</title>
		<link rel="self" type="application/atom+xml" href="https://dosideas.com/wiki/index.php?action=history&amp;feed=atom&amp;title=Bulk_Collect"/>
		<link rel="alternate" type="text/html" href="https://dosideas.com/wiki/index.php?title=Bulk_Collect&amp;action=history"/>
		<updated>2026-05-09T21:39:22Z</updated>
		<subtitle>Historial de revisiones para esta página en el wiki</subtitle>
		<generator>MediaWiki 1.28.2</generator>

	<entry>
		<id>https://dosideas.com/wiki/index.php?title=Bulk_Collect&amp;diff=2983&amp;oldid=prev</id>
		<title>Admin en 18:08 26 ago 2009</title>
		<link rel="alternate" type="text/html" href="https://dosideas.com/wiki/index.php?title=Bulk_Collect&amp;diff=2983&amp;oldid=prev"/>
				<updated>2009-08-26T18:08:48Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class='diff-marker' /&gt;
				&lt;col class='diff-content' /&gt;
				&lt;col class='diff-marker' /&gt;
				&lt;col class='diff-content' /&gt;
				&lt;tr style='vertical-align: top;' lang='es'&gt;
				&lt;td colspan='2' style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Revisión anterior&lt;/td&gt;
				&lt;td colspan='2' style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Revisión del 18:08 26 ago 2009&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l1&quot; &gt;Línea 1:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Línea 1:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Category:Oracle]]&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Category:Oracle]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;−&lt;/td&gt;&lt;td style=&quot;color:black; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;BULK COLLECT es una función de [Oracle] que facilita la selección masiva de información de la base a alta velocidad, permitiendo el fetch de múltiples filas en una o mas colecciones.&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;+&lt;/td&gt;&lt;td style=&quot;color:black; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;BULK COLLECT es una función de &lt;ins class=&quot;diffchange diffchange-inline&quot;&gt;[&lt;/ins&gt;[Oracle&lt;ins class=&quot;diffchange diffchange-inline&quot;&gt;]&lt;/ins&gt;] que facilita la selección masiva de información de la base a alta velocidad, permitiendo el fetch de múltiples filas en una o mas colecciones.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Adicionalmente, el uso del FORALL facilita la ejecución masiva de inserts, updates y deletes, permitiendo transferir la información de una o mas colecciones a la base. Ambas alternativas pueden ser utilizadas de manera conjunta o individual, y la principal implicancia es el incremento en la performance de las operaciones.&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Adicionalmente, el uso del FORALL facilita la ejecución masiva de inserts, updates y deletes, permitiendo transferir la información de una o mas colecciones a la base. Ambas alternativas pueden ser utilizadas de manera conjunta o individual, y la principal implicancia es el incremento en la performance de las operaciones.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	<entry>
		<id>https://dosideas.com/wiki/index.php?title=Bulk_Collect&amp;diff=2982&amp;oldid=prev</id>
		<title>Admin en 18:08 26 ago 2009</title>
		<link rel="alternate" type="text/html" href="https://dosideas.com/wiki/index.php?title=Bulk_Collect&amp;diff=2982&amp;oldid=prev"/>
				<updated>2009-08-26T18:08:31Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class='diff-marker' /&gt;
				&lt;col class='diff-content' /&gt;
				&lt;col class='diff-marker' /&gt;
				&lt;col class='diff-content' /&gt;
				&lt;tr style='vertical-align: top;' lang='es'&gt;
				&lt;td colspan='2' style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Revisión anterior&lt;/td&gt;
				&lt;td colspan='2' style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Revisión del 18:08 26 ago 2009&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l1&quot; &gt;Línea 1:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Línea 1:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot;&gt;&amp;#160;&lt;/td&gt;&lt;td class='diff-marker'&gt;+&lt;/td&gt;&lt;td style=&quot;color:black; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;[[Category:Oracle]]&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;BULK COLLECT es una función de [Oracle] que facilita la selección masiva de información de la base a alta velocidad, permitiendo el fetch de múltiples filas en una o mas colecciones.&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;BULK COLLECT es una función de [Oracle] que facilita la selección masiva de información de la base a alta velocidad, permitiendo el fetch de múltiples filas en una o mas colecciones.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	<entry>
		<id>https://dosideas.com/wiki/index.php?title=Bulk_Collect&amp;diff=280&amp;oldid=prev</id>
		<title>201.251.182.130: Página nueva: BULK COLLECT es una función de [Oracle] que facilita la selección masiva de información de la base a alta velocidad, permitiendo el fetch de múltiples filas en una o mas coleccion...</title>
		<link rel="alternate" type="text/html" href="https://dosideas.com/wiki/index.php?title=Bulk_Collect&amp;diff=280&amp;oldid=prev"/>
				<updated>2008-07-25T14:48:22Z</updated>
		
		<summary type="html">&lt;p&gt;Página nueva: BULK COLLECT es una función de [Oracle] que facilita la selección masiva de información de la base a alta velocidad, permitiendo el fetch de múltiples filas en una o mas coleccion...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Página nueva&lt;/b&gt;&lt;/p&gt;&lt;div&gt;BULK COLLECT es una función de [Oracle] que facilita la selección masiva de información de la base a alta velocidad, permitiendo el fetch de múltiples filas en una o mas colecciones.&lt;br /&gt;
&lt;br /&gt;
Adicionalmente, el uso del FORALL facilita la ejecución masiva de inserts, updates y deletes, permitiendo transferir la información de una o mas colecciones a la base. Ambas alternativas pueden ser utilizadas de manera conjunta o individual, y la principal implicancia es el incremento en la performance de las operaciones.&lt;br /&gt;
&lt;br /&gt;
=Ejemplo=&lt;br /&gt;
&lt;br /&gt;
 create table t1(cod_cliente  number(10),&lt;br /&gt;
                 des_cliente  varchar2(10),&lt;br /&gt;
                 fec_proceso  date);&lt;br /&gt;
&lt;br /&gt;
 create table t2(num_abonado  number(10),&lt;br /&gt;
                 des_abonado  varchar2(10),&lt;br /&gt;
                 cod_cliente  number(10));&lt;br /&gt;
&lt;br /&gt;
 create table t3(cod_cliente  number(10),&lt;br /&gt;
                 des_cliente  varchar2(10),&lt;br /&gt;
                 cnt_abonado  number(10));&lt;br /&gt;
&lt;br /&gt;
 insert  into t1&lt;br /&gt;
 select  rownum,'C' || lpad(rownum,9,0),null&lt;br /&gt;
 from    dual&lt;br /&gt;
 connect by level &amp;lt;= 5000;&lt;br /&gt;
&lt;br /&gt;
 insert  into t2&lt;br /&gt;
 select  rownum,'A' || lpad(rownum,9,0),mod(rownum-1,5000)+1&lt;br /&gt;
 from    dual&lt;br /&gt;
 connect by level &amp;lt;= 20000;&lt;br /&gt;
&lt;br /&gt;
 commit;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Caso 1: sin manejo de excepciones==&lt;br /&gt;
&lt;br /&gt;
 declare&lt;br /&gt;
&lt;br /&gt;
 type tty_rowid       is table of urowid              index by binary_integer;&lt;br /&gt;
 type tty_cod_cliente is table of t3.cod_cliente%type index by binary_integer;&lt;br /&gt;
 type tty_des_cliente is table of t3.des_cliente%type index by binary_integer;&lt;br /&gt;
 type tty_cnt_abonado is table of t3.cnt_abonado%type index by binary_integer;&lt;br /&gt;
&lt;br /&gt;
 tab_rowid       tty_rowid;&lt;br /&gt;
 tab_cod_cliente tty_cod_cliente;&lt;br /&gt;
 tab_des_cliente tty_des_cliente;&lt;br /&gt;
 tab_cnt_abonado tty_cnt_abonado;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 i number := 0;&lt;br /&gt;
&lt;br /&gt;
 cursor cur_test is select  t1.rowid,t1.cod_cliente,t1.des_cliente,count(*)&lt;br /&gt;
                    from     t1,t2&lt;br /&gt;
                    where  t1.cod_cliente = t2.cod_cliente&lt;br /&gt;
                    group by t1.rowid,t1.cod_cliente,t1.des_cliente;&lt;br /&gt;
&lt;br /&gt;
 begin&lt;br /&gt;
  open cur_test;&lt;br /&gt;
  loop&lt;br /&gt;
      fetch cur_test bulk collect into tab_rowid,&lt;br /&gt;
                                       tab_cod_cliente,&lt;br /&gt;
                                       tab_des_cliente,&lt;br /&gt;
                                       tab_cnt_abonado limit 100;&lt;br /&gt;
      exit when tab_rowid.count=0;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
      forall i in 1..tab_rowid.count&lt;br /&gt;
        insert into t3 values(tab_cod_cliente(i),&lt;br /&gt;
                              tab_des_cliente(i),&lt;br /&gt;
                              tab_cnt_abonado(i));&lt;br /&gt;
&lt;br /&gt;
      forall i in 1..tab_rowid.count&lt;br /&gt;
        update t1 set fec_proceso = sysdate where rowid = tab_rowid(i);&lt;br /&gt;
&lt;br /&gt;
      commit;&lt;br /&gt;
&lt;br /&gt;
  end loop;&lt;br /&gt;
&lt;br /&gt;
  close cur_test;&lt;br /&gt;
&lt;br /&gt;
 exception&lt;br /&gt;
   when others then&lt;br /&gt;
      rollback;&lt;br /&gt;
 end;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Caso 2: con manejo de excepciones global==&lt;br /&gt;
&lt;br /&gt;
declare&lt;br /&gt;
&lt;br /&gt;
  type tty_rowid       is table of urowid              index by binary_integer;&lt;br /&gt;
  type tty_cod_cliente is table of t1.cod_cliente%type index by binary_integer;&lt;br /&gt;
  type tty_des_cliente is table of t1.des_cliente%type index by binary_integer;&lt;br /&gt;
  type tty_cnt_abonado is table of t3.cnt_abonado%type index by binary_integer;&lt;br /&gt;
&lt;br /&gt;
  tab_rowid       tty_rowid;&lt;br /&gt;
  tab_cod_cliente tty_cod_cliente;&lt;br /&gt;
  tab_des_cliente tty_des_cliente;&lt;br /&gt;
  tab_cnt_abonado tty_cnt_abonado;&lt;br /&gt;
&lt;br /&gt;
  v_rows_ok  number := 0;&lt;br /&gt;
  v_rows_er  number := 0;&lt;br /&gt;
  i number := 0;&lt;br /&gt;
&lt;br /&gt;
  cursor cur_test is select t1.rowid,t1.cod_cliente,t1.des_cliente,count(*)&lt;br /&gt;
                     from    t1,t2&lt;br /&gt;
                     where  t1.cod_cliente = t2.cod_cliente&lt;br /&gt;
                     group  by t1.rowid,t1.cod_cliente,t1.des_cliente&lt;br /&gt;
                     order  by t1.cod_cliente;&lt;br /&gt;
&lt;br /&gt;
 excp_bulk_error exception;&lt;br /&gt;
 pragma exception_init (excp_bulk_error, -24381 );&lt;br /&gt;
&lt;br /&gt;
 begin&lt;br /&gt;
&lt;br /&gt;
  open cur_test;&lt;br /&gt;
&lt;br /&gt;
  loop&lt;br /&gt;
&lt;br /&gt;
    fetch cur_test bulk collect into tab_rowid,&lt;br /&gt;
                                     tab_cod_cliente,&lt;br /&gt;
                                     tab_des_cliente,&lt;br /&gt;
                                     tab_cnt_abonado limit 100;&lt;br /&gt;
    exit when tab_rowid.count=0;&lt;br /&gt;
&lt;br /&gt;
    forall i in 1..tab_rowid.count save exceptions&lt;br /&gt;
           insert into t3 values(tab_cod_cliente(i),&lt;br /&gt;
                                 tab_des_cliente(i),&lt;br /&gt;
                                 tab_cnt_abonado(i));&lt;br /&gt;
&lt;br /&gt;
    forall i in 1..tab_rowid.count&lt;br /&gt;
           update t1 set fec_proceso = sysdate where rowid = tab_rowid(i);&lt;br /&gt;
&lt;br /&gt;
    commit;&lt;br /&gt;
&lt;br /&gt;
  end loop;&lt;br /&gt;
&lt;br /&gt;
  close cur_test;&lt;br /&gt;
&lt;br /&gt;
 exception&lt;br /&gt;
&lt;br /&gt;
   when excp_bulk_error then&lt;br /&gt;
        p('# Handler global ');&lt;br /&gt;
        v_rows_ok := sql%rowcount;&lt;br /&gt;
        v_rows_er := sql%bulk_exceptions.count;&lt;br /&gt;
        p('# Rows[OK] ',v_rows_ok);&lt;br /&gt;
        p('# Rows[ER] ',v_rows_er);&lt;br /&gt;
        for i in 1..v_rows_er loop&lt;br /&gt;
            p('# Row         ',sql%bulk_exceptions(i).error_index);&lt;br /&gt;
            p('# Code        ',sql%bulk_exceptions(i).error_code);&lt;br /&gt;
            p('# Descripcion ',sqlerrm(-sql%bulk_exceptions(i).error_code));&lt;br /&gt;
        end loop;&lt;br /&gt;
        rollback;&lt;br /&gt;
&lt;br /&gt;
   when others then&lt;br /&gt;
        rollback;&lt;br /&gt;
&lt;br /&gt;
 end;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Caso 3: con manejo de excepciones local==&lt;br /&gt;
&lt;br /&gt;
 declare&lt;br /&gt;
&lt;br /&gt;
  type tty_rowid       is table of urowid              index by binary_integer;&lt;br /&gt;
  type tty_cod_cliente is table of t1.cod_cliente%type index by binary_integer;&lt;br /&gt;
  type tty_des_cliente is table of t1.des_cliente%type index by binary_integer;&lt;br /&gt;
  type tty_cnt_abonado is table of t3.cnt_abonado%type index by binary_integer;&lt;br /&gt;
&lt;br /&gt;
  tab_rowid       tty_rowid;&lt;br /&gt;
  tab_cod_cliente tty_cod_cliente;&lt;br /&gt;
  tab_des_cliente tty_des_cliente;&lt;br /&gt;
  tab_cnt_abonado tty_cnt_abonado;&lt;br /&gt;
&lt;br /&gt;
  v_rows_ok   number := 0;&lt;br /&gt;
  v_rows_er   number := 0;&lt;br /&gt;
  i number := 0;&lt;br /&gt;
&lt;br /&gt;
  cursor cur_test is select t1.rowid,t1.cod_cliente,t1.des_cliente,count(*)&lt;br /&gt;
                     from   t1,t2&lt;br /&gt;
                     where  t1.cod_cliente = t2.cod_cliente&lt;br /&gt;
                     group  by t1.rowid,t1.cod_cliente,t1.des_cliente&lt;br /&gt;
                     order  by t1.cod_cliente;&lt;br /&gt;
&lt;br /&gt;
  excp_bulk_error exception;&lt;br /&gt;
  pragma exception_init (excp_bulk_error, -24381 );&lt;br /&gt;
&lt;br /&gt;
 begin&lt;br /&gt;
&lt;br /&gt;
  open cur_test;&lt;br /&gt;
&lt;br /&gt;
  loop&lt;br /&gt;
&lt;br /&gt;
    fetch cur_test bulk collect into tab_rowid,&lt;br /&gt;
                                     tab_cod_cliente,&lt;br /&gt;
                                     tab_des_cliente,&lt;br /&gt;
                                     tab_cnt_abonado limit 100;&lt;br /&gt;
&lt;br /&gt;
    exit when tab_rowid.count=0;&lt;br /&gt;
&lt;br /&gt;
    begin&lt;br /&gt;
&lt;br /&gt;
      forall i in 1..tab_rowid.count save exceptions&lt;br /&gt;
             insert into t3 values(tab_cod_cliente(i),&lt;br /&gt;
                                   tab_des_cliente(i),&lt;br /&gt;
                                   tab_cnt_abonado(i));&lt;br /&gt;
&lt;br /&gt;
      forall i in 1..tab_rowid.count&lt;br /&gt;
             update t1 set fec_proceso = sysdate where rowid = tab_rowid(i);&lt;br /&gt;
&lt;br /&gt;
   exception&lt;br /&gt;
      when excp_bulk_error then&lt;br /&gt;
            p('# Handler local ');&lt;br /&gt;
            v_rows_ok := sql%rowcount;&lt;br /&gt;
            v_rows_er := sql%bulk_exceptions.count;&lt;br /&gt;
            p('# Rows[OK] ',v_rows_ok);&lt;br /&gt;
            p('# Rows[ER] ',v_rows_er);&lt;br /&gt;
            for i in 1..v_rows_er loop&lt;br /&gt;
               p('# Row         ',sql%bulk_exceptions(i).error_index);&lt;br /&gt;
               p('# Code        ',sql%bulk_exceptions(i).error_code);&lt;br /&gt;
               p('# Descripcion ',sqlerrm(-sql%bulk_exceptions(i).error_code));&lt;br /&gt;
            end loop;&lt;br /&gt;
           rollback;&lt;br /&gt;
    end;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   commit;&lt;br /&gt;
&lt;br /&gt;
 end loop;&lt;br /&gt;
&lt;br /&gt;
 close cur_test;&lt;br /&gt;
&lt;br /&gt;
 exception&lt;br /&gt;
   when others then&lt;br /&gt;
        rollback;&lt;br /&gt;
&lt;br /&gt;
 end;&lt;br /&gt;
&lt;br /&gt;
Estos casos ejemplos y otros relacionados pueden verse en el package th_blkav_pkg&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=Sintaxis=&lt;br /&gt;
&lt;br /&gt;
 SELECT C1,C2,….,CN BULK COLLECT INTO COL1,COL2,….COLN.&lt;br /&gt;
 SELECT C1,C2,….,CN BULK COLLECT INTO COLT.&lt;br /&gt;
 FETCH  C  BULK COLLECT INTO COL1,COL2,….COLN LIMIT MAXROWS&lt;br /&gt;
 FETCH  C  BULK COLLECT INTO COLT LIMIT MAXROWS.&lt;br /&gt;
&lt;br /&gt;
=Sugerencias de Uso=&lt;br /&gt;
Utlizar un LIMIT adecuado para cada fetch, utilizar uno extremadamente grande puede generar problemas de memoria sobre el server.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=Casos prácticos de uso=&lt;br /&gt;
Procesamiento masivo de datos.&lt;br /&gt;
&lt;br /&gt;
=Ver también=&lt;br /&gt;
* [[Oracle]]&lt;/div&gt;</summary>
		<author><name>201.251.182.130</name></author>	</entry>

	</feed>