Re: Is there a better way than this to get the start and end of a month?

Поиск
Список
Период
Сортировка
От Dmitry Tkach
Тема Re: Is there a better way than this to get the start and end of a month?
Дата
Msg-id 3D91CAB0.7080003@openratings.com
обсуждение исходный текст
Ответ на Is there a better way than this to get the start and end of a month?  (David Stanaway <david@stanaway.net>)
Список pgsql-sql
Sorry, the previous message was wrong...

This is better:

create function month_start (date) as
'select date_trunc ('month', $1)::date;'
language 'sql';

create function month_end (date) as
'select month_start ($1) - 1 + interval '1 month';
language 'sql';

I hope, it helps...

Dima






David Stanaway wrote:
> Here are the 2 functions I have at the moment. I was wondering if
> someone had a better way?
> 
> CREATE OR REPLACE FUNCTION month_start (date)
>   RETURNS date
>   AS '
>    DECLARE
>     day ALIAS FOR $1;
>    BEGIN
>     RETURN day - (extract(''day'' FROM day)||'' days'')::interval + 
>     ''1 day''::interval;          
>    END;
>   '
>   LANGUAGE 'plpgsql';
> 
> CREATE OR REPLACE FUNCTION month_end (date)
>   RETURNS date
>   AS '
>    DECLARE
>     day ALIAS FOR $1;
>     month int;
>     year int;
>    BEGIN
>     month := extract(''month'' FROM day);
>     year  := extract(''year'' FROM day);
>     IF month = 12 THEN
>      month := 1;
>      year  := year +1;
>     ELSE
>      month := month +1;
>     END IF;
>     RETURN (''01-''||month||''-''||year)::date - 
>     ''1 day''::interval;
>     END;
>    '
>    LANGUAGE 'plpgsql';
> 
> 




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

Предыдущее
От: Dmitry Tkach
Дата:
Сообщение: Re: Is there a better way than this to get the start and end of a month?
Следующее
От: "Josh Berkus"
Дата:
Сообщение: Re: Timestamp Error - 7.2