微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

MySQL 5.7如何以天为间隔计算总和值?

如何解决MySQL 5.7如何以天为间隔计算总和值?

我有一台装有MysqL 5.7的服务器。 我有两张桌子。前一个t包含每个ID的创建日期。第二个表t0每天包含每个ID的利润记录。 我想获取包含每个ID的第一天和第二30天以及第一天的利润总和的列。

SELECT t.created_at,t.id,sum(t1.profit) profit_1_week,sum(t2.profit) profit_2_week,sum(t3.profit) profit_1_day
FROM t
LEFT JOIN t0 t1 ON t.id = t.id
AND t1.inport_date BETWEEN t.created_at AND DATE_ADD(t.created_at,INTERVAL 30 DAY)
LEFT JOIN t0 t2 ON t.id = t.id
AND t2.inport_date BETWEEN DATE_ADD(t.created_at,INTERVAL 30 DAY) AND DATE_ADD(t.created_at,INTERVAL 60 DAY)
LEFT JOIN t0 t3 ON t.id = t.id
AND t3.inport_date BETWEEN t.created_at AND DATE_ADD(t.created_at,INTERVAL 1 DAY)
GROUP BY t.created_at,t.id
ORDER BY t.created_at

代码运行,但是总和是错误的,因为第一天的总和多于每月。我错在哪里以及如何解决

解决方法

您的问题陈述不清楚,但是根据您的尝试,我怀疑您可以进行条件聚合:

select t.created_at,t.id,sum(case when t0.inport_date >= t.created_at                   and t0.inport_date < t.created_at + interval 30 day then t0.profit else 0 end) profit_1,sum(case when t0.inport_date >= t.created_at + interval 30 day and t0.inport_date < t.created_at + interval 60 day then t0.profit else 0 end) profit_2,sum(case when t0.inport_date >= t.created_at                   and t0.inport_date < t.created_at + interval  1 day then t0.profit else 0 end) profit_3
from t
left join t0 on t0.id = t.id 
group by t.created_at,t.id
order by t.created_at

逻辑是只连接一次,然后在case内使用sum()表达式来选择应考虑的值。

我将日期过滤逻辑更改为使用半开间隔而不是between,因为它似乎与我更相关。您可以根据实际用例随意调整它。

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