2017-07-21 256 views
0

如何在Oracle SQL中解決此問題?在日期日期時間範圍內查找「多日」日期時間範圍內的部分

1.I具有列Event_Min_DateTime(如2017年1月6日7時30分00秒)& Event_Max_datetime(如2017年3月6日十八時三十分00秒)的的EVENT_ID(例如ev001)。因此,計算列Event_minutes可以創建爲(Event_Max_datetime - Event_Min_DateTime)* 24 * 60。

  • 我也有列Daily_Window_Start一個Daily_Date(按順序每一天)的(可變的時間戳值)和Daily_Window_End(可變時間戳值)。因此計算列Daily_Window_minutes可以計算爲(Daily_Window_End-Daily_Window_Start)* 24 * 60。請注意,Daily_Window_minutes將始終爲< = 1440。
  • 現在,如何計算列Daily_portion_withinDaily_portion_outside(所述Event_minutes落入內Daily_Window_minutes的部分)(在Event_minutes的一部分落下以外Daily_Window_minutes但相同內Daily_Date)?

    回答

    0

    這個問題並不清楚Daily_Window_Start是否可以> Event_Min_DateTime,所以在這裏我只考慮寫這種情況。此外,因爲數據類型的列不會從您的問題中看出來,因此不會應用轉換。您可以按照以下指定的方式在Daily_Window_Start> Event_Min_DateTime的類似行上編寫查詢。然而,這裏有很多假設。

    SELECT 
          CASE 
            WHEN e. event_max_datetime <= d.daily_window_end THEN (e.event_max_datetime - e.event_min_datetime)*24*60 
            ELSE (d.daily_window_end             - e.event_min_datetime)*24*60 
          END daily_portion_within , 
          CASE 
            WHEN e. event_max_datetime <= d.daily_window_end THEN NULL 
            ELSE (e.event_max_datetime - d.daily_window_end)*24*60 
          END daily_portion_outside 
        FROM (
            SELECT Trunc(event_max_datetime) dt , 
             event_min_datetime , 
             event_max_datetime 
            FROM EVENTS) EVENTS e, 
          daily_window d 
        WHERE e.dt = trunc(d.dt) 
    
    0

    這個例子應該有所幫助:

    select trunc(d1) as day, inside, (d2 - d1) * 24 * 60 - inside as outside 
        from (select e.*, d.*, 
           case when d2 < e1 or e2 < d1 then 0 
            else least(e2, d2) - greatest(e1, d1) 
           end * 24 * 60 as inside 
          from e cross join d) 
    

    數據:

    create table e (id number(3), e1 date, e2 date); 
    insert into e values(1, timestamp '2017-06-01 07:30:00', timestamp '2017-06-03 18:30:00'); 
    
    create table d (d1 date, d2 date); 
    insert into d values(timestamp '2017-06-01 06:00:00', timestamp '2017-06-01 15:30:00'); 
    insert into d values(timestamp '2017-06-02 09:30:00', timestamp '2017-06-02 22:30:00'); 
    insert into d values(timestamp '2017-06-03 12:05:00', timestamp '2017-06-03 19:45:00'); 
    insert into d values(timestamp '2017-06-04 15:00:00', timestamp '2017-06-04 16:30:00'); 
    

    結果:

    DAY    INSIDE OUTSIDE 
    ----------- ---------- ---------- 
    2017-06-01   480   90 
    2017-06-02   780   0 
    2017-06-03   385   75 
    2017-06-04   0   90