[Mysql]GroupBy分组,按天、周、⽉
简单说明:
  最近在做报表功能的时候,需要将数据按天、周和⽉进⾏合并展⽰(数据记录都是按天20190701)。
正⽂:
  说明:数据表中date都是int类型:如 20190701
  ⼀、按天
SELECT `date`, SUM(`a`)
FROM tb
WHERE 1
GROUP BY `date`
  ⼆、按周
    使⽤WEEK 函数,具体使⽤可以参考⽹上资料。这⾥使⽤模式 5,周⼀作为每周开始。查询出来的记录是SELECT `date`, SUM(a)
FROM `tb`
WHERE `
GROUP BY WEEK(`date`, 5)
date a
2019070110
2019070855
    按周的查询结果如上所⽰:20190701那条记录,表⽰从20190701到20190706区间的汇总。
groupby分组
  三、按⽉
    使⽤YEAR和MONTH函数,根据年和⽉进⾏分组汇总。
SELECT CONCAT(YEAR(`date`), MONTH(`date`)) as `date`, SUM(`a`)
FROM `tb`
WHERE 1
GROUP BY YEAR(`date`), MONTH(`date`)
date SUM(`a`)
2019755
2019866