MUNDOSAP

Regresar   MUNDOSAP > DESARROLLO > Programación ABAP IV
Nombre de Usuario
Contraseña
Home Descargas Registrar FAQ Miembros Calendario Buscar Temas de Hoy Marcar Foros Como Leídos




 
Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Viejo 29/03/11, 22:14:19
acha3318 acha3318 is offline
Senior Member
 
Fecha de Ingreso: abr 2008
Localización: Cali - Colombia
Mensajes: 182
Thumbs down Optimizar Codigo

Saludos a todos,

No se como hacer, para optimizar este codigo el cual se demora demasiado tiempo al rededor de 19 minutos.

Los siguientes son RANGES:
r_matnr
r_werks
r_lgort
r_bwart
r_sobkz

SELECT mblnr mjahr waers zeile bwart matnr werks lgort charg bwtar kzvbr
kzbew sobkz kzzug bustm bustw mengu wertu shkzg menge meins dmbtr
dmbum xauto kzbws insmk smbln sjahr smblp umwrk bstme
INTO TABLE it_lmseg
FROM mseg
FOR ALL ENTRIES IN it_mkpf
WHERE mblnr EQ it_mkpf-mblnr AND
mjahr EQ it_mkpf-mjahr AND
matnr IN r_matnr AND
werks IN r_werks AND
lgort IN r_lgort AND
bwart IN r_bwart AND
sobkz IN r_sobkz.

Si alguien sabe como voltear este codigo para hacerlo mas eficiente recibo comentarios, por otro lado, yo cree indices, por los campos del where y de igual forma se demora.

Gracias por la ayuda que me puedan dar.
Responder Con Cita
  #2  
Viejo 30/03/11, 02:52:48
gib8107 gib8107 is offline
Member
 
Fecha de Ingreso: may 2006
Mensajes: 44
Post ..

Yo he tenido muy mala experiencia con la sentencia for all entries, en lo personal lo cambio a que seleccione de 1000 en 1000 con muy bienos resultados


yo tengo en mi sistema

Sistema operativo Windows 20XX
Tipo máquina 8x AMD64 L

Sistema base datos MSSQL
Release 9.00.2047
Versión componentes SAP ECC 6.0

SAP_ABA 700 0020 SAPKA70020 Componente multiaplicaciones
SAP_BASIS 700 0020 SAPKB70020 Sistema Base SAP
PI_BASIS 2005_1_700 0020 SAPKIPYJ7K PI_BASIS 2005_1_700

pero esta mejora la empezamos a aplicar desde hace como dos años


La idea es seleccionar de 1000 en 1000 los registros (SQL truena con mas de 1500 registros) y cada vez que cambie el año, que son los dos datos que son variables por lo que estas utilizando el for all entries

tambien puedews copiar el programa y aplicarle un trace con la TC ST05 y ver si mejhora o empeora el rendimiento
Responder Con Cita
  #3  
Viejo 30/03/11, 11:22:33
francesc francesc is offline
Member
 
Fecha de Ingreso: mar 2006
Localización: Barcelona
Mensajes: 58
Podrias probar a hacer la selección sólo con la condición de la clave, es decir el campo MBLNR y posteriormente con la tabla interna obtenida aplicar las otras condiciones. Una cosa, ten presente que si la tabla que le pasas al FOR ALL ENTRIES está vacía entonces el SELECT te seleccionará todo el contenido de la tabla de la BB.DD a la que accedes.
Responder Con Cita
  #4  
Viejo 30/03/11, 11:44:00
Avatar de hugoa77
hugoa77 hugoa77 is offline
Senior Member
 
Fecha de Ingreso: may 2010
Mensajes: 130
Hola, coincido con francesc... o tambien te sugeriría que utilices un inner join. Este último suele ser más eficiente que el for all entries...
Nos cuentas como te fue.
Slds,
Responder Con Cita
  #5  
Viejo 31/03/11, 14:52:24
acha3318 acha3318 is offline
Senior Member
 
Fecha de Ingreso: abr 2008
Localización: Cali - Colombia
Mensajes: 182
Optimizar Codigo

Gracias a todos por sus aportes, de todas maneras, la consulta si es pesadita.

Por ahora me toca quedarme asi, hasta que me invente otra cosa.


Gracias a todos.
Responder Con Cita
  #6  
Viejo 31/03/11, 17:07:29
Avatar de hugoa77
hugoa77 hugoa77 is offline
Senior Member
 
Fecha de Ingreso: may 2010
Mensajes: 130
un aporte más... por ahí te aporta un poco de luz...

Optimización en el acceso a la Base de Datos

Unos simples consejos son los siguientes:

Si se va a acceder a varias tablas relaciones, es recomendable crear una vista con las tablas relacionadas y accesar a ella.

Con la opción FOR ALL ENTRIES se consigue que las entradas que se consiguieron en el primer select (tabla driver) se consigan en el segundo select por lo que se ejecutaría el segundo select solo una vez.

SELECT matnr FROM mara INTO TABLE imara WHERE cond.
SELECT * FROM mard FOR ALL ENTRIES IN imara WHERE mantr = imara-matnr.

Con la Instrucción FORL ALL ENTRIES hay que tener sumo cuidado en la manera en que se va a usar, primero se debe asegurar que la tabla driver con la se va a comparar no se encuentre vacia, pues si es así, traería toda la data que esté en la base de datos, perjudicando el performance del programa, y segundo, si la tabla interna tiene muchos registros, el select a la Base de Datos sería mucha mas lento pues si utilizaría mucha memoria.

Para hacer mas eficiente el FOR ALL ENTRIES es recomendable, borrar los valores duplicado de la tabla driver, ordenarla y si es posible convertirla en una tabla de rangos usando la sentencia BETWEEN.

FOR ALL ENTRIES IN imara WHERE matnr >= imara-matnr
AND matnr <= imara-matnr.

Es recomendable y mas rápido indicarle al SELECT que campos va leer, si no se necesitan todos ellos.

SELECT campo1 campo2 campo3 FROM TABLE tabla INTO TABLE itabla.

Donde itabla debe estar declarada con los campos que se quieren seleccionar de la tabla.

Fuente:
Slds
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

Reglas de Mensajes
no puedes crear nuevos temas
no puedes responder temas
no puedes adjuntar archivos
no puedes editar tus mensajes

El código vB está On
Las caritas están On
Código [IMG] está On
Código HTML está Off
Saltar a Foro


Husos Horarios son GMT. La hora en este momento es 10:45:22.


www.mundosap.com 2006 - Spain
software crm, crm on demand, software call center, crm act, crm solutions, crm gratis, crm web