Re: query not using index

Поиск
Список
Период
Сортировка
От Mark Kirkwood
Тема Re: query not using index
Дата
Msg-id 52BE37EF.7090109@catalyst.net.nz
обсуждение исходный текст
Ответ на Re: query not using index  (Johann Spies <johann.spies@gmail.com>)
Список pgsql-performance
On 23/12/13 21:58, Johann Spies wrote:
>
>
>
> On 19 December 2013 16:48, Tom Lane <tgl@sss.pgh.pa.us
> <mailto:tgl@sss.pgh.pa.us>> wrote:
>
>     Johann Spies <johann.spies@gmail.com
>     <mailto:johann.spies@gmail.com>> writes:
>      > I would appreciate some help optimising the following query:
>
>     It's a mistake to imagine that indexes are going to help much with
>     a join of this size.  Hash or merge join is going to be a lot better
>     than nestloop.  What you need to do is make sure those will perform
>     as well as possible, and to that end, it'd likely help to raise
>     work_mem.  I'm not sure if you can sanely put it high enough to
>     make the query operate totally in memory --- it looks like you'd
>     need work_mem of 500MB or more to prevent any of the sorts or
>     hashes from spilling to disk, and keep in mind that this query
>     is going to use several times work_mem because there are multiple
>     sorts/hashes going on.  But if you can transiently dedicate a lot
>     of RAM to this query, that should help some.  I'd suggest increasing
>     work_mem via a SET command in the particular session running this
>     query --- you don't want such a high value to be the global default.
>
>
> Thanks Tom.  Raising work_mem from 384MB to 512MB made a significant
> difference.
>
> You said "hash or merge join id going to be a lot better than
> nestloop".  Is that purely in the hands of the query planner or what can
> I do to get the planner to use that options apart from raising the work_mem?
>
>

You can disable the hash and merge join options by doing:

SET enable_hashjoin=off;
SET enable_mergejoin=off;

before running the query again. Timing it (or EXPLAIN ANALYZE) should
demonstrate if that planner made the right call by choosing hash or
merge in the first place.

regards

Mark



В списке pgsql-performance по дате отправления:

Предыдущее
От: Andreas Karlsson
Дата:
Сообщение: Re: Does fsync on/off for wal AND Checkpoint?
Следующее
От: ankush upadhyay
Дата:
Сообщение: Are there some additional postgres tuning to improve performance in multi tenant system