SQLite select 过去实际 7 天(一周)的数据,如果不存在 null/zero
SQLite select data past actual 7 days ( week ) and if not exist null/zero
我正在构建一个财务应用程序,需要 select 过去 7 天的一些特定数据,即使其中一个日期不存在只是 return 0 或 null
具体来说,我有一个交易 table 并且我需要 return 今天最后 7 天的每天交易总数,而不是数据库中的最后 7 天 return =14=]
所以我需要的是这样的东西!
-----------
total|date
-----------
150 | 22/9
50 | 21/9
0 | 20/9
100 | 19/9
800 | 18/9
1500| 17/9
0 | 16/9
我当前的查询是return每天的交易总数和当天的日期字段
SELECT SUM(value), date as value FROM transactions GROUP BY STRFTIME('%d', DATE(date, 'unixepoch'))
您需要一个 CTE
的递归 returns 前 7 个日期和一个 LEFT
连接到 table 以聚合:
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;
我正在构建一个财务应用程序,需要 select 过去 7 天的一些特定数据,即使其中一个日期不存在只是 return 0 或 null
具体来说,我有一个交易 table 并且我需要 return 今天最后 7 天的每天交易总数,而不是数据库中的最后 7 天 return =14=]
所以我需要的是这样的东西!
-----------
total|date
-----------
150 | 22/9
50 | 21/9
0 | 20/9
100 | 19/9
800 | 18/9
1500| 17/9
0 | 16/9
我当前的查询是return每天的交易总数和当天的日期字段
SELECT SUM(value), date as value FROM transactions GROUP BY STRFTIME('%d', DATE(date, 'unixepoch'))
您需要一个 CTE
的递归 returns 前 7 个日期和一个 LEFT
连接到 table 以聚合:
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;