zoukankan      html  css  js  c++  java
  • mysql按时间统计数据,没有数据的时候自动补充0

    1.数据库中选择任意一个有数据的表,例如我选择的是 shopping_user 表

    SELECT
        @cdate := DATE_ADD( @cdate, INTERVAL - 1 DAY ) `date`,
        0 AS `sum` 
    FROM
        ( SELECT @cdate := DATE_ADD( CURDATE( ), INTERVAL + 1 DAY ) FROM shopping_user ) t1 
    WHERE
        @cdate > '2017-08-03'

       选择一统计时间开始时间,我的开始时间选择的是2017-08-03,结束时间默认是当前日期。

    2.将自己要统计的数据,按我们自己的要求写出来,当然此时,肯定显示的都是有数据的记录统计结果:

       我这是查询的shopping_hibitRecord 按照ADDTIME 统计的条数 

    SELECT
            DATE_FORMAT( ADDTIME, '%Y-%m-%d' ) AS `date`,
            COUNT( * ) AS 'sum' 
        FROM
            `shopping_hibitRecord` 
        WHERE
            shopping_hibitRecord.`ADDTIME` >= '2017-08-03' 
            AND deleteStatus = FALSE 
            AND TYPE = 0 
        GROUP BY
            DATE DESC   

    此时没有记录的时间,就没有展示在结果中。

    3.联合查询将没有记录的时间补0

    SELECT
        `date`,
        MAX( `sum` ) AS `sum` 
    FROM
        (
        SELECT
            @cdate := DATE_ADD( @cdate, INTERVAL - 1 DAY ) `date`,
            0 AS `sum` 
        FROM
            ( SELECT @cdate := DATE_ADD( CURDATE( ), INTERVAL + 1 DAY ) FROM shopping_user ) t1 
        WHERE
            @cdate > '2017-08-03' UNION ALL
        SELECT
            DATE_FORMAT( ADDTIME, '%Y-%m-%d' ) AS `date`,
            COUNT( * ) AS 'sum' 
        FROM
            `shopping_hibitRecord` 
        WHERE
            shopping_hibitRecord.`ADDTIME` >= '2017-08-03' 
            AND deleteStatus = FALSE 
            AND TYPE = 0 
        GROUP BY
            DATE DESC 
        ) _tmpAllTable 
    GROUP BY
        `date` DESC

     上面要求1、2 的记录条数字段名字一样,我选择的都是 sum

      结果就是没有数据的时间补上数据0了

       

    总结:当然还有别的方法,不过这个方法不用创建任何的存储过程,是相对来说简单一点的

  • 相关阅读:
    MySql跨服务器备份数据库
    html特殊字符过滤
    PHP简单去掉文件里面的空行和重复行
    汉字转拼音首字母缩写
    php 时间配置
    兼容ie6、ie7和firefox的div控制最小高度又自适高度的设置
    JBoss AS7:Timeout deploying JBoss applications
    中国经纬度范围
    CSS 架构
    linux 下 rpm 安装mysql
  • 原文地址:https://www.cnblogs.com/wyf-love-dch/p/11072931.html
Copyright © 2011-2022 走看看