#1
|
|||
|
|||
Tabla Interna Con 200000 Registros
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?.
__________________
Consultor Técnico B1/ABAP |
#2
|
||||
|
||||
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 saludos.
__________________
Sebastián Chiavia |
#3
|
|||
|
|||
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 Cambialo a 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 |
#4
|
|||
|
|||
Estoy trabajando con FIELD-SYMBOLS.
Este es el código en cuestión.
__________________
Consultor Técnico B1/ABAP |
#5
|
|||
|
|||
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 |
#6
|
|||
|
|||
Soy muy nuevo en el tema pero por conceptos que vi podrias ingresar
UP TO 10000 ROWS dentro del loop, . saludos. |
Herramientas | Buscar en Tema |
Desplegado | |
|
|