SQL 根据日期分组统计问题

2016-03-07 15:07:39 +08:00
 lyning

mysql

表 A:
id | date | count

需求: 想将表 A 里面的字段 count 按照 当前年 往前 推 11 年 再根据(年 月 日)分组统计
例如:
year | yearCount | month | monthcount | day | dayCount
2016 1000 01 120 02 5
2016 1000 01 120 03 3
...
2016 1000 12 110 01 10
...
2015 900 01 100 03 5
...
2005 800 01 120 03 3
...
2005 800 12 80 12 7

我的 sql 是这么写的, 请教(更优化 更好看 更有效率)的写法, 因为我写的这一段 sql 实在不怎么好看, 而且很罗嗦, 可能还存在问题
SELECT tt.*, DATE_FORMAT(t.date,'%d') day, SUM(t.count) day_count
FROM A t3,

(SELECT t.*, DATE_FORMAT(t2.date,'%m') month, SUM(t2.count) month_count
FROM A t2,

    (SELECT YEAR(t.recycle_date) year, SUM(t1.count)/1000 year_count
    FROM A t1 WHERE YEAR(t1.date)>=(YEAR(curdate())-11)
    GROUP BY YEAR(t1.date)) t

WHERE YEAR(t1.date)=re.year 
GROUP BY DATE_FORMAT(t2.date,'%Y-%m')) tt

WHERE YEAR(t3.date)=tt.year AND MONTH(t3.date)=tt.month
GROUP BY DATE_FORMAT(t3.date,'%Y-%m-%d')
ORDER BY tt.year, tt.month, day ASC;

2938 次点击
所在节点    MySQL
2 条回复
iyaozhen
2016-03-07 15:42:31 +08:00
我一般就统计到日。然后有月和年的需求的话业务层自己处理。这样也比较灵活。
lyning
2016-03-07 16:03:28 +08:00
@iyaozhen 哇哦, 这个建议不错

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/261682

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX