sql >> Database teknologi >  >> RDS >> Oracle

Har brug for Oracle SQL for at opdele dato/tidsinterval efter dag

Det er muligt at gøre dette i SQL. Der er to tricks. Den første er at generere en række tal, som du kan gøre med en CTE ved hjælp af connect .

Den anden er at sammensætte den rigtige logik for at udvide datoerne, samtidig med at de rigtige tidspunkter for begyndelsen og slutningen holdes.

Følgende er et eksempel:

with n as (
      select level n
      from dual connect by level <= 20
     ),
     t as (
      select 1 as id, to_date('01/01/2000 4', 'mm/dd/yyyy hh') as StartDate, to_date('01/03/2000 6', 'mm/dd/yyyy hh') as EndDate from dual union all
      select 2 as id, to_date('01/04/2000 8', 'mm/dd/yyyy hh') as StartDate, to_date('01/04/2000 12', 'mm/dd/yyyy hh') as EndDate from dual union all
      select 3 as id, to_date('01/05/2000', 'mm/dd/yyyy') as StartDate, to_date('01/06/2000', 'mm/dd/yyyy') as EndDate from dual
     )
select t.id,
       (case when n = 1 then StartDate
             else trunc(StartDate + n - 1)
        end) as StartDate,
       (case when trunc(StartDate + n - 1) = trunc(enddate)
             then enddate
             else trunc(StartDate + n)
        end)
from t join
     n
     on StartDate + n - 1 <= EndDate
order by id, StartDate

Her er den på SQLFiddle.



  1. Implementering af en multi-datacenter-opsætning til PostgreSQL - del 1

  2. Hvordan kan jeg se forespørgsler, der udføres mod Oracle?

  3. 7 måder at finde duplikerede rækker i SQL Server, mens du ignorerer enhver primær nøgle

  4. Oracle PL/SQL-masseindsamling med Gem undtagelser Eksempel