Oracle
 sql >> Baza danych >  >> RDS >> Oracle

Scal zakresy dat

Pracownik A ma dwa rzędy od 01.07.2013 do 08.10.2014; Założyłem, że to pomyłka i usunąłem jeden z wierszy.

Poza tym jest to zastosowanie „metody tabibitosan” do rozwiązywania problemów „luk i wysp” dla zakresów dat. Sztuczka polega na tworzeniu "grup" (gp ) dla sąsiednich interwałów.

with
     prep ( id, st_dt, end_dt, gp, pos, locn, status ) as (
       select id, st_dt, end_dt, 
              end_dt - sum( end_dt - st_dt + 1 ) over (partition by id, pos, locn, status 
                                                       order by st_dt),
              pos, locn, status
       from   asgn
     )
select id, min(st_dt) as st_dt, max(end_dt) as end_dt, pos, locn, status
from   prep
group by id, gp, pos, locn, status
order by id, st_dt
;



ID         ST_DT      END_DT     POS        LOCN           STATUS
---------- ---------- ---------- ---------- ---------- ----------
A          12-31-2006 08-16-2009 CLERK      LAX                 3
A          08-17-2009 10-04-2009 CLERK      LAX                 0
A          10-05-2009 04-09-2013 OPR        NYC                 3
A          04-10-2013 08-10-2014 CLERK      LAX                 3
B          04-10-2013 05-31-2013 SUP        LAX                 3
B          06-01-2013 06-30-2014 SUP        LAX                 0
B          07-01-2013 08-10-2014 SUP        LAX                 3
B          08-11-2014 08-11-2014 CLERK      NYC                 3
B          08-12-2014 02-10-2016 SUP        LAX                 3
B          02-11-2016 08-12-2016 OPER       SFO                 3

 10 rows selected 



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Jak utworzyć indeks dla dynamicznych ciągów wyszukiwania

  2. Złączenie zewnętrzne Oracle z warunkiem filtrowania w drugiej tabeli

  3. Dzielenie ciągów w PL/SQL

  4. Entity Framework Oracle i Sql Server - jak zbudować aplikację niezależną od bazy danych

  5. Przezwyciężenie ograniczeń dotyczących zbiorczych wstawek za pośrednictwem łącza do bazy danych