| From: | Kevin Grittner <kgrittn(at)ymail(dot)com> | 
|---|---|
| To: | Andrew Dunstan <andrew(at)dunslane(dot)net>, Vlad Arkhipov <arhipov(at)dc(dot)baikal(dot)ru>, David Rowley <dgrowleyml(at)gmail(dot)com> | 
| Cc: | pgsql-performance <pgsql-performance(at)postgresql(dot)org> | 
| Subject: | Re: Postgres does not use indexes with OR-conditions | 
| Date: | 2014-11-07 14:17:31 | 
| Message-ID: | 1415369851.48766.YahooMailNeo@web122305.mail.ne1.yahoo.com | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-performance | 
Andrew Dunstan <andrew(at)dunslane(dot)net> wrote:
> On 11/07/2014 12:06 AM, Vlad Arkhipov wrote:
>> I need to rewrite it in the way below to make Postgres use the index.
>>
>> select *
>> from commons.financial_documents fd
>> where fd.creation_time <= '2011-11-07 10:39:07.285022+08'
>>  and (
>>    fd.creation_time < '2011-11-07 10:39:07.285022+08'
>>      or (fd.creation_time = '2011-11-07 10:39:07.285022+08' and
>> fd.financial_document_id < 100)
>>  )
>> order by fd.creation_time desc
>> limit 200
>
> Could you not rewrite it as something this?:
>
>     where fd.creation_time <= '2011-11-07 10:39:07.285022+08'
>         and (fd.creation_time < '2011-11-07 10:39:07.285022+08'
>               or fd.financial_document_id < 100)
Yeah, when there are two ways to write a query that are logically
equivalent, it is better to put the AND at the higher level than
the OR.  On the other hand, why not simply write it as?:
select *
  from commons.financial_documents fd
  where (fd.creation_time, fd.financial_document_id)
      < ('2011-11-07 10:39:07.285022+08', 100)
  order by fd.creation_time desc
  limit 200
--
Kevin Grittner
EDB: http://www.enterprisedb.com
The Enterprise PostgreSQL Company
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Tom Lane | 2014-11-07 15:11:48 | Re: Postgres does not use indexes with OR-conditions | 
| Previous Message | Shaun Thomas | 2014-11-07 14:13:20 | Re: pgtune + configurations with 9.3 |