PDA

Ver la Versión Completa : Tabla Interna Con 200000 Registros


AJAA
29/10/10, 19:47:17
Buenas tardes,

Estoy haciendo un loop a una tabla interna con 200000 registros y el mismo se me tarda como hora y media.

Antes de hacer ese loop hago otro a una tabla interna que tiene mas o menos la misma cantidad de registro y este se tarda solo 4 minutos.

He probado liberando las tablas que ya no uso con REFRESH y FREE.

He comentado todo lo que hago dentro del Loop y solo lo dejo correr pero nada todo sigue igual.

Existe alguna forma de paginar una tabla interna, es decir, leer los primero 10.000.

Que se les ocurre?.

mysmb2
29/10/10, 19:59:17
Hola podes probar paquetizarlo usando dos tablas internas una tiene todo los valores(i_tabla_full) y otra con el volumen de registros a procesar(i_tabla_tmp).

Espero se entienda


DO.
* armo la tabla interna con d_packsize registros
REFRESH i_tabla_tmp.
DO d_packsize TIMES.
UNASSIGN <fs_tabla_all>.
READ TABLE i_tabla_all INDEX 1 ASSIGNING <fs_tabla_all>.
IF sy-subrc IS NOT INITIAL.
EXIT.
ENDIF.
APPEND <fs_tabla_all> TO i_tabla_tmp.
DELETE i_tabla_all INDEX 1.
ENDDO.


IF i_tabla_tmp[] IS INITIAL.
EXIT.
ENDIF.

PERFORM proceso TABLES i_tabla_tmp."se procesan el paquete de registro

ENDDO.



saludos.

Tu amo
29/10/10, 20:29:02
A mi me suena a otra cosa, un loop de esa cantidad, del tamaño que sea, por si solo no deberia tardar tanto

Digamos que te creo. Estas haciendo un loop a una work area?
Que pasa si lo haces con un assigning a un field-symbol

en vez de esto

loop at itab into wa.
endloop.


Cambialo a

loop at itab assigning <itab>.
endloop.


Lo segundo evita la copia y en teoria deberia ser mas rapido. Pero a menos que la cantidad de informacion por linea sea descomunal incluso lo primero deberia ser rapido

AJAA
29/10/10, 20:52:40
Estoy trabajando con FIELD-SYMBOLS.

Este es el código en cuestión.




LOOP AT IT_RESULT ASSIGNING <WA_RESULT>.

READ TABLE IT_NEW ASSIGNING <WA_NEW> WITH KEY CAMPO1 = <WA_RESULT>-CAMPO1.

IF SY-SUBRC = 0.
IF ( <WA_RESULT>-CAMPO2 > <WA_NEW>-CAMPO2 )
<WA_NEW>-CAMPO2 = <WA_RESULT>-CAMPO2.
...
...
...
ENDIF.
ELSE.
APPEND INITIAL LINE TO IT_NEW ASSIGNING <WA_NEW>.
MOVE-CORRESPONDING <WA_RESULT> TO <WA_NEW>.
ENDIF.
ENDLOOP.
UNASSING <WA_NEW>.
UNASSIGN <WA_RESULT>.

Tu amo
29/10/10, 22:14:19
Ahi esta tu problema
Probablemente es el read adentro del loop.
Mal hecho eso puede ser peligroso. Me acuerdo mucho de un programa parecido (un loop de millones leyendo una tabla de miles) que tardaba como 5-6 horas y ya arreglado corria como 3-5 minutos.

De dos.
1. Ordenas it_new y lees con binary search
2. Vuelves it_new una tabla hash.

La opcion 2 seria la mas eficiente si it_new tiene muchos registros, pero tambien puede ser la mas laboriosa de implementar.
Tu decides, en todo caso cualquiera de las dos debe darte una buena mejora

charly_ap
31/10/10, 06:06:41
Soy muy nuevo en el tema pero por conceptos que vi podrias ingresar
UP TO 10000 ROWS
dentro del loop, :) .

saludos.