Re: Numero de semana + fechas

From: Jaime Casanova <jcasanov(at)systemguards(dot)com(dot)ec>
To: Raúl Andrés Duque Murillo <ra_duque(at)yahoo(dot)com(dot)mx>
Cc: Jorge Diaz <jorge(dot)diaz(dot)t(at)gmail(dot)com>, pgsql-es-ayuda(at)postgresql(dot)org
Subject: Re: Numero de semana + fechas
Date: 2010-01-14 16:10:39
Message-ID: 3073cc9b1001140810w5bd7aa84r1b4f956c7d7123cf@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-es-ayuda

2010/1/14 Raúl Andrés Duque Murillo <ra_duque(at)yahoo(dot)com(dot)mx>:
> Que tal Jorge.
>
> Utilizando un generate_series puedes lograr tu objetivo de forma sencilla.
>

Pero aun prefiero la forma con el WITH RECURSIVE, es mas elegante ;)

select to_char(extract(week from (f1 + (i || ' weeks')::interval)),
'09') as num,
(f1 + (i || ' weeks')::interval)::date,
(f2 + (i || ' weeks')::interval)::date
from (select f1, f1 + 6 as f2
from (select (current_date -
(extract(week from current_date) - 1 || '
weeks')::interval)::date -
(extract(dow from current_date)::integer - 1) as f1
) as foo1
) as foo2, generate_series(0, 52) as i
where extract(year from (f1 + (i || ' weeks')::interval)) = 2010

en forma de función:

CREATE OR REPLACE FUNCTION fechas_anio(anio integer) RETURNS SETOF record AS
$$
select to_char(extract(week from (f1 + (i || ' weeks')::interval)),
'09') as num,
(f1 + (i || ' weeks')::interval)::date,
(f2 + (i || ' weeks')::interval)::date
from (select f1, f1 + 6 as f2
from (select (($1 || '-02-01')::date -
(extract(week from ($1 || '-02-01')::date) -
1 || ' weeks')::interval)::date -
(extract(dow from ($1 ||
'-02-01')::date)::integer - 1) as f1
) as foo1
) as foo2, generate_series(0, 52) as i
where extract(year from (f1 + (i || ' weeks')::interval)) = $1;
$$ language sql

y lo llamarías asi (fijate que debes incluir el formato de retorno o
crear un tipo para esto):

select * from fechas_anio(2010) as (semana text, fecha_inicial date,
fecha_final date)

--
Atentamente,
Jaime Casanova
Soporte y capacitación de PostgreSQL
Asesoría y desarrollo de sistemas
Guayaquil - Ecuador
Cel. +59387171157

In response to

Responses

Browse pgsql-es-ayuda by date

  From Date Subject
Next Message Jaime Casanova 2010-01-14 16:12:37 Re: error en esquema public
Previous Message Lorena Gpe. M. Osorio 2010-01-14 14:46:07 Re: error en esquema public