Oracle
 sql >> база данни >  >> RDS >> Oracle

Обединяване на периоди от време

Служител A има два реда за 07-01-2013 до 08-10-2014; Предположих, че това е грешка и изтрих един от редовете.

Освен това, това е приложение на „метода на табибитозан“ за решаване на проблеми с „празнини и острови“ за периоди от време. Номерът е в създаването на „групите“ (gp ) за съседни интервали.

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. Низ до дата в Oracle с милисекунди

  2. Как да изберете колони от таблица, които имат стойности, различни от null?

  3. как да направя тригер като ограничение на първичен ключ?

  4. Колона нееднозначно дефинирана

  5. Как да добавя номер на ред в рамките на група в моята заявка