Re: Date for a week day of a month

Поиск
Список
Период
Сортировка
От hubert depesz lubaczewski
Тема Re: Date for a week day of a month
Дата
Msg-id 9e4684ce0707040158w3573972ev412263bb11ebe3d4@mail.gmail.com
обсуждение исходный текст
Ответ на Date for a week day of a month  (Emi Lu <emilu@encs.concordia.ca>)
Ответы Re: Date for a week day of a month  (Emi Lu <emilu@encs.concordia.ca>)
Список pgsql-general
On 7/3/07, Emi Lu <emilu@encs.concordia.ca> wrote:
Can I know how to get the date of each month's last Thursday please?
Query:  select getDateBaseOnWeekday('2007-04-01', 'Last Thursday');
Result: 2007-04-26

you can easily do it without functions.
for example, this select:
SELECT
    cast(d.date + i * '1 day'::interval as date)
FROM
    (select '2007-04-01'::date as date) d,
    generate_series(0, 30) i
WHERE
    to_char(d.date , 'MM') = to_char( cast(d.date + i * '1 day'::interval as date), 'MM')
    AND to_char(cast(d.date + i * '1 day'::interval as date), 'D') = '5'
ORDER BY 1 DESC
LIMIT 1
;
does what you need.
to get last-thursday for another month, just change: (select '2007-04-01'::date as date) d, to be 1st of any other month.

depesz

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

Предыдущее
От: "hubert depesz lubaczewski"
Дата:
Сообщение: Re: tsearch2 questions
Следующее
От: Joshua N Pritikin
Дата:
Сообщение: Re: tsearch2 questions