最近在工作中接到了一个需求,要求统计当月以10天为一个周期,每个周期的数据汇总信息。假设有一张表如下:
表table_test中
ID AMOUNT CREATE_DATE
1 50 2017-01-01
2 50 2017-01-09
3 50 2017-01-11
4 50 2017-01-19
5 50 2017-01-21
6 50 2017-01-22
7 50 2017-01-24
相当于以CREATE_DATE为组条件,1 - 10,11 -20,21 - 月末,每一个时间段的AMOUNT字段的和。面对这个需求,首先想到的解决方案为以日期作为参数。使用代码传参重复调用,发现该方法效率极低,后来做出相应优化,使用 UNION ALL 去调用 sql如下
1