微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

SQL Group和Sum By Month – 默认为零

我目前正在按月分组和汇总库存使用情况:
SELECT      Inventory.itemid AS ItemID,SUM(Inventory.Totalunits) AS Individual_MonthQty,MONTH(Inventory.dadded) AS Individual_MonthAsNumber,DATENAME(MONTH,Inventory.dadded) AS Individual_MonthAsstring
FROM        Inventory
WHERE       Inventory.invtype = 'Shipment'
AND         Inventory.dadded >= @StartRange
AND         Inventory.dadded <= @EndRange
GROUP BY    Inventory.ItemID,MONTH(Inventory.dadded),Inventory.dadded)

这给了我期待的结果:

ItemID  Kit_MonthQty    Kit_MonthAsNumber   Kit_MonthAsstring
13188   234             8                   August
13188   45              9                   September
13188   61              10                  October
13188   20              12                  December

在没有数据存在的月份,我必须做什么才能返回零,如下所示:

ItemID  Kit_MonthQty    Kit_MonthAsNumber   Kit_MonthAsstring
13188   0               1                   January
13188   0               2                   February
13188   0               3                   march
13188   0               4                   April
13188   0               5                   May
13188   0               6                   June
13188   0               7                   July
13188   234             8                   August
13188   45              9                   September
13188   61              10                  October
13188   0               11                  November
13188   20              12                  December

解决方法

在过去,我通过创建一个临时表来解决这样的问题,该表将保存所需的所有日期:
CREATE TABLE #AllDates (ThisDate datetime null)
    SET @CurrentDate = @StartRange

    -- insert all dates into temp table
    WHILE @CurrentDate <=  @EndRange
        BEGIN
            INSERT INTO #AllDates values(@CurrentDate)
            SET @CurrentDate = dateadd(mm,1,@CurrentDate)
        END

然后,修改您的查询以加入此表:

SELECT      ALLItems.ItemId,SUM(COALESCE(Inventory.Qty,0)) AS Individual_MonthQty,MONTH(#AllDates.ThisDate) AS Individual_MonthAsNumber,#AllDates.ThisDate) AS Individual_MonthAsstring
FROM        #AllDates
            JOIN (SELECT disTINCT dbo.Inventory.ItemId FROM dbo.Inventory)  AS ALLItems ON 1 = 1
            LEFT JOIN Inventory ON DATEADD(dd,- DAY(Inventory.dadded) +1,Inventory.dadded) = #AllDates.ThisDate AND ALLItems.ItemId = dbo.Inventory.ItemId
WHERE       
            #AllDates.ThisDate >= @StartRange
AND         #AllDates.ThisDate <= @EndRange
GROUP BY    ALLItems.ItemId,#AllDates.ThisDate

那么你应该有一个每个月的记录,无论它是否存在于库存中.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐