Cómo acelerar una consulta utilizando la función y la indexación en Informix

votos
0

Bajo Informix Dbms necesito para acelerar esta consulta:

set isolation to dirty read;
SELECT NVL(hr_dati1, '---'), NVL(cm_t_stoc, -1) as type,
LPAD(cm_mod,3, 0)||LPAD(cm_col,3, 0) as coord,
NVL(cm_segmento, 0) as seg, NVL(cm_lres, 0) 
FROM informix.artind, informix.coordman
LEFT OUTER JOIN informix.hmdescr ON cm_t_stoc = hr_key_soc AND 
hr_key_pref = 'MGZ' AND hr_key_suff = 'STOCC'
WHERE cm_magaz = '5' AND ad_code = '2065498' AND 
((cm_code = '2065498') OR
((cm_code = ad_coor_r) AND ( SUBSTR(NVL(ad_coor_r, ' '), 1, 2) = 'MU' )
AND
( SUBSTR(NVL(cm_code, ' '), 1, 2) = 'MU' ) ))
ORDER BY type, seg, coord;

La consulta anterior fue más rápido cuando he usado como filtro sólo

(cm_code = '2065498')

en lugar de

((cm_code = '2065498') OR
((cm_code = ad_coor_r) AND ( SUBSTR(NVL(ad_coor_r, ' '), 1, 2) = 'MU')      
AND
( SUBSTR(NVL(cm_code, ' '), 1, 2) = 'MU' ) ))

pero ahora un tengo que añadir esta nueva condición.

En la búsqueda de una optimización, y yo creo que la lentitud se debe a la substr He creado esta función:

create function informix.substr2_ad_coor_r(coor_r char(8))
  returning char(8) with (NOT VARIANT);
  return substr(coor_r, 1, 2);
end function;

y los índices de estos:

create index informix.artind_idx_sub_coor_r on informix.artind
 ( informix.substr2_ad_coor_r(ad_coor_r));

create index informix.coordman_idx_sub_codifa on informix.coordman
 ( informix.substr2_ad_coor_r(cm_codifa));

pero no he mejorado la velocidad suficiente, también lo extraño es que la consulta parece más rápido si uso, en la condición de filtro, por ejemplo, substr. (SUBSTR(NVL(ad_coor_r, ' '), 1, 2) = 'MU') en lugar de substr2_ad_coor_r por ejemplo.substr2_ad_coor_r(ad_coor_r) = 'MU'

Publicado el 19/09/2018 a las 13:32
fuente por usuario
En otros idiomas...                            


1 respuestas

votos
0

Yo aceleré la consulta dividiéndola en 2 usando la unión:

set isolation to dirty read;
SELECT NVL(hr_dati1, '---'), NVL(cm_t_stoc, -1) as type,
LPAD(cm_mod,3, 0)||LPAD(cm_col,3, 0) as coord,
NVL(cm_segmento, 0) as seg, NVL(cm_lres, 0)
FROM informix.artind, informix.coordman
LEFT OUTER JOIN informix.hmdescr ON cm_t_stoc = hr_key_soc AND
hr_key_pref = 'MGZ' AND hr_key_suff = 'STOCC'
WHERE cm_magaz = '5' AND ad_code = '2065498' AND
(cm_code = '2065498')
UNION
SELECT NVL(hr_dati1, '---'), NVL(cm_t_stoc, -1) as type,
LPAD(cm_mod,3, 0)||LPAD(cm_col,3, 0) as coord,
NVL(cm_segmento, 0) as seg, NVL(cm_lres, 0)
FROM informix.artind, informix.coordman
LEFT OUTER JOIN informix.hmdescr ON cm_t_stoc = hr_key_soc AND
hr_key_pref = 'MGZ' AND hr_key_suff = 'STOCC'
WHERE cm_magaz = '5' AND ad_code = '2065498' AND
((cm_code = ad_coor_r) AND ( SUBSTR(NVL(ad_coor_r, ' '), 1, 2) = 'MU' )
AND
( SUBSTR(NVL(cm_code, ' '), 1, 2) = 'MU' ) )
ORDER BY 1, 3, 2;
Respondida el 01/10/2018 a las 08:34
fuente por usuario

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more