Oracle
 sql >> Cơ Sở Dữ Liệu >  >> RDS >> Oracle

Hợp nhất các phạm vi ngày

Nhân viên A có hai hàng từ 07-01-2013 đến 08-10-2014; Tôi cho rằng đó là một sự nhầm lẫn và tôi đã xóa một trong các hàng.

Ngoài ra, đây là một ứng dụng của "phương pháp tabibitosan" để giải quyết các vấn đề "khoảng cách và đảo" cho các phạm vi ngày. Bí quyết là tạo "nhóm" (gp ) cho các khoảng thời gian liền kề.

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. Bảo mật cơ sở dữ liệu Oracle - Mã hóa và giải mã

  2. cảnh báo:hàm được tạo với lỗi biên dịch

  3. Oracle:trình tự MySequence.currval chưa được xác định trong phiên này

  4. Oracle SQL chuyển đổi định dạng ngày từ DD-Mon-YY sang YYYYMM

  5. JdbcPagingItemReader trong lô Spring không cho kết quả chính xác