Re: Understanding sequential versus index scans. - Mailing list pgsql-general

From Tom Lane
Subject Re: Understanding sequential versus index scans.
Date
Msg-id 11961.1248047260@sss.pgh.pa.us
Whole thread Raw
In response to Understanding sequential versus index scans.  (Robert James <srobertjames@gmail.com>)
Responses Re: Understanding sequential versus index scans.
List pgsql-general
Robert James <srobertjames@gmail.com> writes:
> Hi.  I notice that when I do a WHERE x, Postgres uses an index, and when I
> do WHERE y, it does so as well, but when I do WHERE x OR y, it
> doesn't.

It can use indexes for OR conditions, but not for arbitrary OR
conditions...

> select * from dict
> where
>  word in (select substr('moon', 0, generate_series(3,length('moon')))) --
> this is my X above
>  OR word like 'moon%' -- this is my Y above

... and that one is pretty arbitrary.  You might have some luck with
using a UNION instead, viz

select * from dict where X
union all
select * from dict where Y

            regards, tom lane

pgsql-general by date:

Previous
From: Greg Stark
Date:
Subject: Re: Understanding sequential versus index scans.
Next
From: John R Pierce
Date:
Subject: Re: Understanding sequential versus index scans.