El 30/09/2013 01:16 p.m., Carlos Eduardo Sotelo Pinto escribió:
> Hola Alvaro
>
> He solucionado parcialmente el problema haciendo una consulta del tipo
>
> arr := regexp_split_to_array(_imeis, E'\\s+');
> RETURN QUERY
> SELECT
> gpstracking_device_tracks.....
> FROM (
> SELECT
> gpstracking_device_tracks......
> ROW_NUMBER() OVER(PARTITION BY gpstracking_device_tracks.imei ORDER BY
> gpstracking_device_tracks.date_time_process DESC) as rnumber
> FROM gpstracking_device_tracks
> WHERE gpstracking_device_tracks.imei = ANY(arr)
> AND gpstracking_device_tracks.date_time_process >= date_trunc('hour',
> now())
> AND gpstracking_device_tracks.date_time_process <= NOW()
> ) AS gpstracking_device_tracks
> WHERE gpstracking_device_tracks.rnumber = 1;
>
> Y ahora estoy leyendo un poco de tuning, ya que no soy un dba ni menos
> un experto en optimización, pero espero pueda mejorar aun más el
> rendimiento
>
> Muchas gracias por la ayuda de todos
>
>
>
>
> El 30 de septiembre de 2013 11:12, Alvaro
> Herrera<alvherre(at)2ndquadrant(dot)com <mailto:alvherre(at)2ndquadrant(dot)com>>
> escribió:
>
> Carlos Eduardo Sotelo Pinto escribió:
>
> > DECLARE
> > arr varchar[];
> > BEGIN
> > arr := regexp_split_to_array(_imeis, E'\\s+');
> > FOR i IN 1..array_length(arr, 1) LOOP
> > RETURN QUERY
>
> Creo que deberías hacer una única consulta con todos los elementos del
> array, en lugar de una consulta para cada elemento. Es decir, elimina
> el LOOP y el LIMIT 1, y tu WHERE debería ser algo como
>
> ...
>
> > FROM gpstracking_device_tracks
> > WHERE gpstracking_device_tracks.imei = arr[i]::VARCHAR
>
> WHERE gpstracking_device_tracks.imei = ANY (arr) AND ...
>
> Vas a tener que solucionar de otra forma el que te retorne sólo
> una fila
> para cada imei, claro.
>
> --
> Álvaro Herrera http://www.2ndQuadrant.com/
> PostgreSQL Development, 24x7 Support, Training & Services
>
>
>
>
> --
> Carlos Eduardo Sotelo Pinto | http://carlossotelo.com | csotelo(at)twitter
> GNU Linux Admin | PHP Senior Web Developer
> Mobil: RPC (Claro)+51, 958194614 | Mov: +51, 959980794
> GTalk: carlos(dot)sotelo(dot)pinto(at)gmail(dot)com
> <mailto:carlos(dot)sotelo(dot)pinto(at)gmail(dot)com> | Skype: csotelop
> MSN: carlos(dot)sotelo(dot)pinto(at)gmail(dot)com
> <mailto:carlos(dot)sotelo(dot)pinto(at)gmail(dot)com> | Yahoo: csotelop
> GNULinux RU #379182 | GNULinux RM #277661
> GPG FP:697E FAB8 8E83 1D60 BBFB 2264 9E3D 5761 F855 4F6B
que indices tenes en la tabla?, como están armados?
la tabla tiene históricos o la depuraras cada cierto tiempo?
Saludos Fernando