0

重複の可能性:
SQL グループと月ごとの合計 - デフォルトはゼロ

私のテーブルには、いくつかの月と年のレコードがありません。そのため、そのレコードに「0」を入力し、「2006」から「2012」までのすべての月と年を結果に表示する必要があります。提案してください

前もって感謝します

4

1 に答える 1

0

ダミーはあなたの本当のテーブルです...

WITH DummyDates (Date) AS (
    SELECT DATEADD(DAY, DATEDIFF(DAY, 0, '20121231') - DATEDIFF(DAY, '20060101', '20121231'), 0)
        UNION ALL SELECT DATEADD(DAY, 1, Date)
            FROM DummyDates
            WHERE DATEADD(DAY, 1, Date) <= '20121231')
SELECT DatePart(yy,DummyDates.Date) as [Year],DATEPART(MM,DummyDates.Date) as [Month],SUM(Case when dummy.date is null then 0 else 1 end) as cnt
FROM DummyDates 
LEFT Join dummy on dummy.Date=DummyDates.Date
Group by DatePart(yy,DummyDates.Date),DATEPART(MM,DummyDates.Date)
Order by DatePart(yy,DummyDates.Date),DATEPART(MM,DummyDates.Date)
OPTION (MAXRECURSION 0)
于 2012-12-06T07:38:04.020 に答える