Re : optimize query with a maximum(date) extraction

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Great idea !

with your second solution, my query seem to use the index on date. but the global performance is worse :-(

I will keep th original solution !

Lot of thanks, Gregory

jsubei

----- Message d'origine ----
De : Gregory Stark <stark@xxxxxxxxxxxxxxxx>
À : JS Ubei <jsubei@xxxxxxxx>
Cc : pgsql-performance@xxxxxxxxxxxxxx
Envoyé le : Mercredi, 5 Septembre 2007, 14h06mn 01s
Objet : Re: optimize query with a maximum(date) extraction

"Gregory Stark" <stark@xxxxxxxxxxxxxxxx> writes:

> "JS Ubei" <jsubei@xxxxxxxx> writes:
>
>> I need to improve a query like :
>>
>> SELECT id, min(the_date), max(the_date) FROM my_table GROUP BY id;
>...
> I don't think you'll find anything much faster for this particular query. You
> could profile running these two (non-standard) queries:
>
> SELECT DISTINCT ON (id) id, the_date AS min_date FROM my_table ORDER BY id, the_date ASC
> SELECT DISTINCT ON (id) id, the_date AS max_date FROM my_table ORDER BY id, the_date DESC

Something else you might try:

select id, 
       (select min(the_date) from my_table where id=x.id) as min_date,
       (select max(the_date) from my_table where id=x.id) as max_date
  from (select distinct id from my_table)

Recent versions of Postgres do know how to use the index for a simple
ungrouped min() or max() like these subqueries.

This would be even better if you have a better source for the list of distinct
ids you're interested in than my_table. If you have a source that just has one
record for each id then you won't need an extra step to eliminate duplicates.

-- 
  Gregory Stark
  EnterpriseDB          http://www.enterprisedb.com





      _____________________________________________________________________________ 
Ne gardez plus qu'une seule adresse mail ! Copiez vos mails vers Yahoo! Mail

---------------------------(end of broadcast)---------------------------
TIP 5: don't forget to increase your free space map settings


[Postgresql General]     [Postgresql PHP]     [PHP Users]     [PHP Home]     [PHP on Windows]     [Kernel Newbies]     [PHP Classes]     [PHP Books]     [PHP Databases]     [Yosemite]

  Powered by Linux