Ein externer Partitions-Join kann helfen, die fehlenden Daten zu erstellen. Erstellen Sie eine Reihe von Monaten und fügen Sie diese Werte für jede Zeile nach Monat hinzu, und führen Sie die Verknüpfung für jeden Buchtyp einmal durch. Ich habe die Monate Januar bis April in diesem Beispiel:
with test_data as
(
select to_date('01-JAN-2010', 'DD-MON-YYYY') month, 'A' book_type, 100 sold_in_dollars from dual union all
select to_date('01-JAN-2010', 'DD-MON-YYYY') month, 'B' book_type, 120 sold_in_dollars from dual union all
select to_date('01-FEB-2010', 'DD-MON-YYYY') month, 'A' book_type, 50 sold_in_dollars from dual union all
select to_date('01-MAR-2010', 'DD-MON-YYYY') month, 'A' book_type, 60 sold_in_dollars from dual union all
select to_date('01-MAR-2010', 'DD-MON-YYYY') month, 'B' book_type, 30 sold_in_dollars from dual
)
select book_type, month, sold_in_dollars
,case when denominator = 0 then 'N/A' else to_char(numerator/denominator) end expected_sales
from
(
select test_data.book_type, all_months.month, sold_in_dollars
,count(sold_in_dollars) over
(partition by book_type order by all_months.month rows between 2 preceding and 1 preceding) denominator
,sum(sold_in_dollars) over
(partition by book_type order by all_months.month rows between 2 preceding and 1 preceding) numerator
from
(
select add_months(to_date('01-JAN-2010', 'DD-MON-YYYY'), level-1) month from dual connect by level <= 4
) all_months
left outer join test_data partition by (test_data.book_type) on all_months.month = test_data.month
)
order by book_type, month
Er will 120/1, nicht (120 + 0)/2, was albern ist. – milan
Schließen Sie die Werte an und führen Sie sie aus. – SteveCav
Soweit ich weiß, ignoriert Durchschnitt Nullen, also, wenn Sie über zwei Zeilen Durchschnitt und einer der Werte ist Null, dann wird nur durch 1 geteilt. –