[Mysql] GroupBy 分组,按天周月
Posted reader
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[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 | |
20190701 | 10 | |
20190708 | 55 |
按周的查询结果如上所示:20190701那条记录,表示从20190701到20190706区间的汇总。
三、按月
使用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`) | |
20197 | 55 | |
20198 | 66 |
以上是关于[Mysql] GroupBy 分组,按天周月的主要内容,如果未能解决你的问题,请参考以下文章