Re: Group by with insensitive order

Поиск
Список
Период
Сортировка
От hubert depesz lubaczewski
Тема Re: Group by with insensitive order
Дата
Msg-id 20110119211733.GA21425@depesz.com
обсуждение исходный текст
Ответ на Group by with insensitive order  (Aram Fingal <fingal@multifactorial.com>)
Список pgsql-general
On Wed, Jan 19, 2011 at 03:37:58PM -0500, Aram Fingal wrote:
> Suppose I'm doing a group by query like the following:
>
> SELECT drug1, drug2, AVG(response)
> FROM data
> GROUP BY drug1, drug2
>
> The problem is that the same drug may appear sometimes as drug1 and
> sometimes as drug2.  So, for example, the combination "aspirin,
> acetaminophen" may also appear as "acetaminophen, aspirin" and I want
> these grouped together in the query.  Is there a simple way to do
> this?

instead of drug1 write: least(drug1, drug2) and instead of drug2 write:
greatest(drug1, drug2) - both in select and group by.

Best regards,

depesz

--
Linkedin: http://www.linkedin.com/in/depesz  /  blog: http://www.depesz.com/
jid/gtalk: depesz@depesz.com / aim:depeszhdl / skype:depesz_hdl / gg:6749007

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

Предыдущее
От: John R Pierce
Дата:
Сообщение: Re: PostgreSQL 9.0.1 PITR can not copy WAL file
Следующее
От: frank joerdens
Дата:
Сообщение: Re: debug_print_plan logs table alias used in join, not table name itself