码迷,mamicode.com
首页 > 数据库 > 详细

[Mysql] GroupBy 分组,按天、周、月

时间:2019-07-27 09:41:18      阅读:245      评论:0      收藏:0      [点我收藏+]

标签:size   groupby   order   sof   需要   bsp   select   tab   网上   

简单说明:

  最近在做报表功能的时候,需要将数据按天、周和月进行合并展示(数据记录都是按天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 分组,按天、周、月

标签:size   groupby   order   sof   需要   bsp   select   tab   网上   

原文地址:https://www.cnblogs.com/reader/p/11253814.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!