Re: [pgsql-es-ayuda] Re: [pgsql-es-ayuda] Re: [pgsql-es-ayuda] Fwd: Help on ṕerformance

From: Carlos Eduardo Sotelo Pinto <carlos(dot)sotelo(dot)pinto(at)gmail(dot)com>
To: Rodriguez Fernando <rodriguez(at)ort(dot)edu(dot)uy>
Cc: pgsql-es-ayuda(at)postgresql(dot)org
Subject: Re: [pgsql-es-ayuda] Re: [pgsql-es-ayuda] Re: [pgsql-es-ayuda] Fwd: Help on ṕerformance
Date: 2013-09-30 16:35:08
Message-ID: CAEhw=E-+YBrDYEDpAN1bgisFU4HgZ2Qy0Twkvr=Pk--m1147fQ@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-es-ayuda pgsql-general pgsql-performance

Hola Fernando

No soy experto en el tema, por ahora trato de llevarme de lo que encuentro

- La tabla esta particionada por meses
- indices en el imei y fecha
- no se manejo de historicos

saludos

El 30 de septiembre de 2013 11:31, Rodriguez
Fernando<rodriguez(at)ort(dot)edu(dot)uy>escribió:

> 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
> > 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 | Skype: csotelop
> MSN: 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
>

--
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 | Skype: csotelop
MSN: 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

In response to

Browse pgsql-es-ayuda by date

  From Date Subject
Next Message Gonzalo Martinez 2013-09-30 21:05:57 Buenas a todos
Previous Message Rodriguez Fernando 2013-09-30 16:31:30 Re: [pgsql-es-ayuda] Re: [pgsql-es-ayuda] Fwd: Help on ṕerformance

Browse pgsql-general by date

  From Date Subject
Next Message Moshe Jacobson 2013-09-30 20:48:01 Inconsistent behavior with unnamed columns
Previous Message Rodriguez Fernando 2013-09-30 16:31:30 Re: [pgsql-es-ayuda] Re: [pgsql-es-ayuda] Fwd: Help on ṕerformance

Browse pgsql-performance by date

  From Date Subject
Next Message Jeff Janes 2013-09-30 17:44:46 Re: pg_statio_all_tables columns
Previous Message Rodriguez Fernando 2013-09-30 16:31:30 Re: [pgsql-es-ayuda] Re: [pgsql-es-ayuda] Fwd: Help on ṕerformance