|
#1
|
|||
|
|||
jajaja pero que esta pasando aquí? jajaja la fotos que les puedo dar es la del tremendo error que me genera sap cuando hago muchos left jejejejeje conformense con saber que son 100 90 60 jajaja no mentira
|
#2
|
|||
|
|||
¿ Puedes colocar el texto completo del DUMP que te genero? |
#3
|
|||
|
|||
He hecho una prueba con varios joins y no me da ningún problema.
select vbak~vbeln into table t_ from vbak left outer join vbap on vbak~vbeln = vbap~vbeln inner join mara on vbap~matnr = mara~matnr inner join MAKT on mara~matnr = makt~matnr and spras = sy-langu INNER JOIN TVak on vbak~auart = TVAK~auart inner join TVAU on vbak~augru = tvau~augru. Igual viendo el dump podríamos hacernos alguna idea más concreta. Puedes probar, a ir haciendo la sql por parte, primero el left join a ver si si que recoges datos y después ir añadiendo cada uno de los inner join, a ver en qué punto te da error. También podrías sustituir los inner join por for all entries in. Pierdes rendimiento pero podría valerte. Un saludo. |
#4
|
|||
|
|||
Hacer un join para obtener un campo de una tabla no es muy eficiente. Por ejemplo, para obtener el nombre del material metes en el join a la MAKT para obtener solo el maktx.
Es mejor ver con los datos de los que partes, no se si el material sera uno de ellos y obtener de la MARD los que vas a tratar y meterlos en una TI_MARD. Luego haces un select into table a una tabla interna for all entries de los materiales que tienes en TI_MARD por el campo que relacione las dos tablas. Y finalmete recorres la tabla TI_MARD actualizando el campo maktx a partir de esa segunda TI, haciendo un read table. Las TI las puedes definir incluso ordenadas para que vaya mas rapido. Si consigues sacar mas de una tabla del join, el rendimiento mejorará. Pero debes tener cuidado con los for all entries, que si no lo haces bien, puede ser hasta peor. |
#5
|
||||
|
||||
+1 Si fuera face le diera Like IT.... Adicional, el unico problema con el FOR ALL ENTRIES es que lo hagas con una tabla interna vacía, solo se debe tener cuidado de no ejecutar el select cuando la tabla está vacía y listo, lo demas debe andar bien. Y viendo el select la verdad si está bien pesado, mas vale hacer muchisimas mas líneas de código pero con buen performance que una sola línea que matara el servidor, Siem ya puso un pequeño "How to do" y recomiendo que sea de esa forma.
__________________
------------------- ¿Dudas para descargar manuales? Ver este tema -> |
Herramientas | Buscar en Tema |
Desplegado | |
|
|