Hi, this is my first post, sorry for my english, I'm chilean and my first
language is spanish.
I don't know if somebody got this solved, but here we go:

I was surfing the net for the fastest query that let me to
get the max movement from a production
plus associated columns related to this production, everywhere I got "use a
subquery to get the
max movement", so, I did write:

 select mov.cod_produccion, mov.cod_ubicacion, mov.ind_salida,
mov.cod_movimiento as max_movimiento
 from producciones pro
 inner join movimientos mov
 on mov.cod_produccion=pro.cod_produccion and mov.cod_movimiento=
 (select max(mov2.cod_movimiento) from movimientos mov2 where
mov2.cod_produccion=pro.cod_produccion)
 where mov.cod_ubicacion=5 and not mov.ind_salida

that was a good answer but too slow... :(
My database has 71727 rows in "producciones" table and 112266 rows in
"movimientos" table, then the
response time for this query was 31531ms, getting 587 rows as result.
Looking the help, and understanding which is the difference between WHERE
and HAVING, I try to optimize that
query to get a better response time and got it:

 select mov1.cod_produccion, mov1.cod_ubicacion, mov1.ind_salida, max(
mov2.cod_movimiento) as max_movimiento
 from producciones pro
 inner join movimientos mov1
 on mov1.cod_produccion=pro.cod_produccion
 inner join movimientos mov2
 on mov2.cod_produccion=pro.cod_produccion
 group by mov1.cod_produccion, mov1.cod_ubicacion, mov1.ind_salida,
mov1.cod_movimiento
 having mov1.cod_movimiento=max(mov2.cod_movimiento) and
mov1.cod_ubicacion=5 and not mov1.ind_salida
 order by mov1.cod_produccion

the response time now was 297ms, even with "order by", getting the same 587
rows as result.

the table fields are:

movimientos
------------------
cod_movimiento   (pk) (serial)
cod_produccion    (fk) (int4)
cod_ubicacion      (fk) (int4)
fec_movimiento    (timestamp)
ind_salida            (bool)

producciones
--------------------
cod_produccion    (pk) (serial)
cod_dia_laboral    (fk)  (int4)
cod_producto       (fk)  (int4)
fec_produccion     (timestamp)
pso_produccion    (numeric(10,2))

My test computer is:
 Hardware: Sempron 2400+, 512Mb. RAM, 80Gb. 7200RPM.
 Software: Windows XP Professional, PostgreSQL (of course :).

This look like standard SQL and would work in any DBMS, so my question is:
Are really those querys getting
the same results?

Thank in advance for your answer.

Good bye.
Greeting from Chile.

César A. León Mansilla./

Reply via email to