sql >> Database >  >> RDS >> PostgreSQL

Krijg het totale tijdsinterval van meerdere rijen als de reeks niet wordt verbroken

Er is misschien een manier om dit in één SQL-select te doen, maar het ontgaat me. Het is me echter gelukt met één opgeslagen functie. Dit is wat ik deed voor mijn testen:

create table work
(id integer, start_date date, end_date date);

insert into work values (1, '2011-01-01','2011-02-02');
insert into work values (1, '2011-02-02','2011-04-04');
insert into work values (1, '2011-06-06','2011-09-09');
insert into work values (2, '2011-01-01','2011-02-02');
insert into work values (2, '2011-02-02','2011-03-03');

create or replace function get_data() returns setof work as
$body$
declare
    res work%rowtype;
    sd  date := null;
begin
    for res in
        select
            w1.id,
            case when exists (select 1 from work w2 where w1.id=w2.id and w2.end_date=w1.start_date) then null else w1.start_date end,
            case when exists (select 1 from work w2 where w1.id=w2.id and w2.start_date=w1.end_date) then null else w1.end_date end
        from
            work w1
        order by
            id, start_date, end_date
    loop
        if res.start_date is not null and res.end_date is not null then
            return next res;
        elsif res.start_date is not null then
            sd := res.start_date;
        elsif res.end_date is not null then
            res.start_date := sd;
            return next res;
        end if;
    end loop;

    return;
end;$body$
  language 'plpgsql';

Dan

select * from get_data() order by id, start_date;

heeft dit resultaat geretourneerd:

 id | start_date |  end_date
----+------------+------------
  1 | 2011-01-01 | 2011-04-04
  1 | 2011-06-06 | 2011-09-09
  2 | 2011-01-01 | 2011-03-03
(3 rows)

dat is, denk ik, wat je zoekt.



  1. Wijzigingen op entiteiten opslaan:is MySQL de juiste oplossing?

  2. Een web-app maken die offline kan werken, gegevens kan opslaan en deze vervolgens kan synchroniseren met MySQL op afstand wanneer u online bent?

  3. Tomcat, Java &SQL Server 2008 R2:Kan JDBC-stuurprogramma van klasse '' niet maken voor verbindings-URL 'null'

  4. heroku rake db:migreer ERROR gem installeer activerecord-mysql-adapter