• [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  
  • 相关阅读:
    js中的字符串
    JSOP
    jq总结1
    jq总结
    诗和远方-志
    诗和远方-感
    js判断变量是否为空字符串、null、undefined
    判断js对象是否为空
    诗和远方-悟
    深复制
  • 原文地址:https://www.cnblogs.com/reader/p/11253814.html
Copyright © 2020-2023  润新知