|
#1
|
|||
|
|||
..
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 |
#2
|
|||
|
|||
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.
|
#3
|
||||
|
||||
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, |
#4
|
|||
|
|||
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. |
#5
|
||||
|
||||
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 |
Herramientas | Buscar en Tema |
Desplegado | |
|
|