Re: SELECT DISTINCT too slow

Поиск
Список
Период
Сортировка
От Greg Stark
Тема Re: SELECT DISTINCT too slow
Дата
Msg-id 87k680hoa3.fsf@stark.xeocode.com
обсуждение исходный текст
Ответ на Re: SELECT DISTINCT too slow  (Alvaro Herrera <alvherre@commandprompt.com>)
Ответы Re: SELECT DISTINCT too slow
Список pgsql-sql
Alvaro Herrera <alvherre@commandprompt.com> writes:

> Miroslav ?ulc wrote:
> > Well, "key" is not primary key from another table. It is just a column
> > in pair "key" => "value".
> > The structure of the table is this:
> > 
> > Id (primary key)
> > MRTPContactId (id of contact from table MRTPContact)
> > Key (key from pair key => value)
> > Value (value from pair key => value)
> > 
> > So I want the get the list of keys used in the table.
> 
> The plan you get is the most efficient possible for that query.  If you
> had a table of possible keys (which should of course be FK of "Key"),
> you could get a much faster version :-)

Actually you could try the equivalent query:
SELECT Key FROM MRTPContactValue GROUP BY Key

This may or may not be faster because it can use a hash aggregate plan. I
would expect it to be faster here because there are few distinct keys and the
planner predicts that. 

Eventually these two queries should be handled the same by Postgres but Hash
Aggregates are a new addition and DISTINCT/DISTINCT ON hasn't been adapted to
make use of them.

Also, incidentally, I don't see how a table of possible keys could help you
here. Nothing forces they table MRTPContactValue to use all possible keys...

-- 
greg



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

Предыдущее
От: Alvaro Herrera
Дата:
Сообщение: Re: SELECT DISTINCT too slow
Следующее
От: Miroslav Šulc
Дата:
Сообщение: Re: SELECT DISTINCT too slow