首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >计数group by日期零结果

计数group by日期零结果
EN

Stack Overflow用户
提问于 2013-05-09 00:54:18
回答 1查看 224关注 0票数 2

我使用下面的SQL来获取报告:

代码语言:javascript
复制
select 
    count(id_reg) total, 
    YEAR(fechaingreso) ano, 
    MONTH(fechaingreso) mes, 
    DAY(fechaingreso) Dia 
from 
    vw_casos_tc 
where 
    fechaingreso between '2012-12-05' and '2013-5-8' 
group by  
    DAY(fechaingreso), MONTH(fechaingreso), YEAR(fechaingreso) 
order by 
    Ano, Mes, dia

除了当count(id_reg) =0时没有记录的日子之外,它工作得很好,这些天不会出现在我的结果中。

代码语言:javascript
复制
total   ano     mes     dia
-----------------------------
66  2012    12  13
22  2012    12  14
23  2012    12  17

没有针对(2012 12 15和2012 12 16)的结果。如何修改我的脚本以获得total =0的这几天?

EN

回答 1

Stack Overflow用户

发布于 2013-05-09 01:11:54

以下是假设SQL Server 2008的一种方法(尽管您可以很容易地为SQL Server 2005修改它):

代码语言:javascript
复制
DECLARE @StartDate DATE, @EndDate DATE
SET @StartDate = '20121205'
SET @EndDate = '20130508';

WITH AllDays AS
(
    SELECT @StartDate YourDate
    UNION ALL
    SELECT DATEADD(DAY,1,YourDate)
    FROM AllDays
    WHERE DATEADD(DAY,1,YourDate) <= @EndDate
)
SELECT  A.YourDate,
        ISNULL(B.Total,0) Total
FROM AllDays A
LEFT JOIN ( SELECT  CONVERT(DATE,fechaingreso) YourDate,
                    COUNT(id_reg) Total
            FROM vw_casos_tc
            WHERE fechaingreso >= @StartDate 
              AND fechaingreso < DATEADD(DAY, 1, @EndDate)
            GROUP BY CONVERT(DATE,fechaingreso)) B
    ON A.YourDate = B.YourDate
OPTION(MAXRECURSION 0)
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16446131

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档