显示日期范围内的所有结果,用零替换空记录

如何解决显示日期范围内的所有结果,用零替换空记录

我正在查询特定日期出现的日志计数。但是在某些日子里,没有记录我正在搜索的日志记录。如何将这些天的计数设置为 0 并返回包含日期范围内完整日期集的结果?

SELECT r.LogCreateDate,r.Docs
FROM(
    SELECT SUM(TO_NUMBER(REPLACE(ld.log_detail,'Total Documents:',''))) AS Docs,to_char(l.log_create_date,'YYYY-MM-DD') AS LogCreateDate
    FROM iwbe_log l
    LEFT JOIN iwbe_log_detail ld ON ld.log_id = l.log_id
    HAVING to_char(l.log_create_date,'YYYY-MM-DD') BETWEEN '2020-01-01' AND '2020-01-07'
    GROUP BY to_char(l.log_create_date,'YYYY-MM-DD')
    ORDER BY to_char(l.log_create_date,'YYYY-MM-DD') DESC
    ) r
ORDER BY r.logcreatedate

当前结果 - 我想包含 01、04、05 和 0 个文档。

LOGCREATEDATE 文档
2020-01-02 7
2020-01-03 3
2020-01-06 6
2020-01-07 1

解决方法

您首先需要一个完整的日期列表,然后将日志数据外部连接到该列表。有多种方法可以生成日期列表,但现在公用表表达式 (cte) 是一种 ANSI 标准方法,如下所示:

with cte (dt) as (
    select to_date('2020-01-01','yyyy-mm-dd') as dt from dual -- start date here
    union all
    select dt + 1 from cte
    where dt + 1 < to_date('2020-02-01','yyyy-mm-dd') -- finish (the day before) date here
    )
select to_char(cte.dt,'yyyy-mm-dd') as LogCreateDate,r.Docs 
from cte
left join (
    SELECT SUM(TO_NUMBER(REPLACE(ld.log_detail,'Total Documents:',''))) AS Docs,trunc(l.log_create_date) AS LogCreateDate
    FROM iwbe_log l
    LEFT JOIN iwbe_log_detail ld ON ld.log_id = l.log_id
    HAVING trunc(l.log_create_date) BETWEEN to_date('2020-01-01','yyyy-mm-dd' AND to_date('2020-01-07','yyyy-mm-dd')
    GROUP BY trunc(l.log_create_date)
    ) r on cte.dt = r.log_create_date
order by cte.dt

此外,在处理日期时,我更喜欢将它们转换为字符串,直到最终输出为止,这使您仍然可以获得正确的日期顺序和最大查询效率。

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

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?