Ver Mensaje Individual
  #4  
Viejo 25/11/09, 12:01:28
martin89 martin89 is offline
Member
 
Fecha de Ingreso: may 2009
Mensajes: 53


Buen día, ojalá pueda aydarte.
Lo mejor y más performance es hacer lo que dice ifloresb. Igualmente estaría bueno que entiendas masomenos por qué no te anda lo que vos planteas.
Según lo que entiendo lo que vos queres es lo siguiente (corregime si me equivoco):
- Modificar la tabla tab_dades. Según lo que veo vos la loopeas, esto quiere decir que ya tenes algunos registros en la tabla y lo que queres hacer es recuperar otros e ir completándola.

En primer lugar hacés bien en loopearla en una estructura (siempre y cuando esa estructura se corresponda con la tabla). Al momento de hacer el loop se van a ir asignando los valores de cada uno de los registros (uno por cada vuelta) a la estructura que utilizás.
Entonces, vos los datos los vas a tener en la estructura. Por lo tanto, en las condicioens de los selects debés utilizar la estructura.
ej.
SELECT SINGLE *
FROM jest
INTO jest
WHERE objnr EQ tab_dades-objnr --> Utilizar la estructura
AND stat LIKE cst_stat
AND inact EQ ' '. " cst_stat ha de començar per 'E'


Una vez que hayas termiando de recuperar todos los datos que te faltan, y que la estrucutra esté completita. Debés modificar la tabla (justo antes de terminar el loop) utilizando un MODIFY tablainterna FROM estructura. Creo qe le tenés qe agregar el índice también (INDEX) que lo sacás del sy-tabix.
BUeno espero que te haya servido por lo menos para entender por qué no te andaba el código. El paso siguiente sería ver como mejorar la performance. Para eso hacele caso a ifloreb utilizando for all entries y algunos read tables.

Bueno, espero no haberte aburrido jaja. Saludos!
Responder Con Cita