首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQLite选择超过实际7天(周)的数据,如果不存在,则为null/零

SQLite选择超过实际7天(周)的数据,如果不存在,则为null/零
EN

Stack Overflow用户
提问于 2021-09-23 09:16:17
回答 1查看 63关注 0票数 1

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

具体地说,我有一个transactions表,并且有一个值,我需要返回今天最后7天的每天事务总数,而不是数据库上最后7天的事务总数

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

代码语言:javascript
复制
-----------
total|date
-----------
150 | 22/9
50  | 21/9
0   | 20/9
100 | 19/9
800 | 18/9
1500| 17/9
0   | 16/9

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

代码语言:javascript
复制
SELECT SUM(value), date as value FROM transactions GROUP BY STRFTIME('%d', DATE(date, 'unixepoch'))
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-09-23 13:15:17

您需要一个返回前7个日期的递归CTE和一个到要聚合的表的LEFT连接:

代码语言:javascript
复制
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;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69297243

复制
相关文章

相似问题

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