Re: CASE in ORDER BY clause

Поиск
Список
Период
Сортировка
От Viatcheslav Kalinin
Тема Re: CASE in ORDER BY clause
Дата
Msg-id 468E66CA.8090208@ipcb.net
обсуждение исходный текст
Ответ на CASE in ORDER BY clause  (Louis-David Mitterrand <vindex+lists-pgsql-general@apartia.org>)
Список pgsql-general
Louis-David Mitterrand wrote:
> Hi,
>
> I am trying the following:
>
>     critik=# select start_date from show_date order by case when start_date > CURRENT_DATE then start_date desc else
start_dateasc end; 
>     ERROR:  syntax error at or near "desc"
>     LINE 1: ...se when start_date > CURRENT_DATE then start_date desc else
>     ...
>
> If I remove the "desc" and "asc" then the quey is accepted but doesn't
> do what I want.
>
> OTOH if I try:
>
>     critik=# select start_date from show_date order by start_date case when start_date > CURRENT_DATE then desc else
ascend; 
>     ERROR:  syntax error at or near "case"
>     LINE 1: ...ect start_date from show_date order by start_date case when ...
>
> How can i order ASC or DESC depending on a condition?
>
> Thanks,
>
> ---------------------------(end of broadcast)---------------------------
> TIP 3: Have you checked our extensive FAQ?
>
>                http://www.postgresql.org/docs/faq
>
Try this:

# select start_date from show_date
# order by
# case when start_date > CURRENT_DATE then start_date end desc,
#      when start_date <= CURRENT_DATE then start_date end asc;




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

Предыдущее
От: Perry Smith
Дата:
Сообщение: Re: Polymorphic delete help needed
Следующее
От: Andreas 'ads' Scherbaum
Дата:
Сообщение: Re: Problem with autovacuum and pg_autovacuum