SQLite 选择过去 7 天(周)的数据,如果不存在,则为空/零

Posted

技术标签:

【中文标题】SQLite 选择过去 7 天(周)的数据,如果不存在,则为空/零【英文标题】:SQLite select data past actual 7 days ( week ) and if not exist null/zero 【发布时间】:2021-11-16 16:32:27 【问题描述】:

我正在构建一个财务应用程序,需要选择一些实际过去 7 天的特定数据,即使其中一个日期不存在也只返回 0 或 null

具体来说,我有一个交易表并且具有价值,我需要返回今天最后 7 天每天的交易总数,而不是数据库中的最后 7 天

所以我需要的是这样的东西!

-----------
total|date
-----------
150 | 22/9
50  | 21/9
0   | 20/9
100 | 19/9
800 | 18/9
1500| 17/9
0   | 16/9

我当前的查询返回每天的交易总数和当天的日期字段

SELECT SUM(value), date as value FROM transactions GROUP BY STRFTIME('%d', DATE(date, 'unixepoch'))

【问题讨论】:

【参考方案1】:

您需要一个返回前 7 个日期的递归 CTE 和一个 LEFT 加入表以进行聚合:

WITH week(date) AS (
  SELECT date('now', '-7 day') 
  UNION ALL 
  SELECT date(date, '+1 day') 
  FROM week 
  WHERE date < date('now', '-1 day') 
)
SELECT TOTAL(t.value) total, 
       strftime('%d/%m', w.date) date
FROM week w LEFT JOIN transactions t
ON date(t.date, 'unixepoch') = w.date
GROUP BY w.date
ORDER BY w.date DESC;

【讨论】:

谢谢你,这就是我想要的!

以上是关于SQLite 选择过去 7 天(周)的数据,如果不存在,则为空/零的主要内容,如果未能解决你的问题,请参考以下文章

如何从当前日期 PHP 获取最近 7 周、7 个月的日期范围?

MySql 单表,选择过去 7 天并包含空行

MySQL 选择过去 7 天

SQLite 按选定日期范围内的所有日期分组,即使数据不存在

计算本周 SQLite 数据库中的行数

我正在制作一个 SQLite 数据库,但我有许多类似的表 - 有没有办法将它们组合起来?