Oracle
 sql >> Teknologi Basis Data >  >> RDS >> Oracle

Gabungkan rentang tanggal

Karyawan A memiliki dua baris untuk 01-07-2013 hingga 10-08-2014; Saya berasumsi itu adalah kesalahan dan saya menghapus salah satu baris.

Selain itu, ini adalah aplikasi dari "metode tabibitosan" untuk memecahkan masalah "celah dan pulau" untuk rentang tanggal. Caranya adalah dengan membuat "grup" (gp ) untuk interval yang berdekatan.

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. Masukkan beberapa baris dari R Dataframe ke Oracle Database

  2. Bagaimana cara mengimpor backupset Oracle 11g RMAN di server database baru?

  3. CSV di Pengembang SQL…

  4. Bergabung terlalu lama

  5. ORA-24247:akses jaringan ditolak oleh daftar kontrol akses (ACL)