mysql获取近7天每天数据,无数据补0
2017-09-19 11:52
2851 查看
接到老大排的活,需要作出一个统计最近7天每天的数据做统计用,最终呈现出这样的效果;
图1
因为公司库里面所有关于时间都是直接存储时间戳,给我带来了一定的处理上的难度,幸好网上找到一个很好的想法;http://blog.csdn.net/ouyang111222/article/details/77638826
处理方式是:构建一个最近7天的结果集,没有的利用ifnull函数补0操作;
最终的sql如下:
其中有个地方需要注意一下:由于我的时间是时间戳类型,而curdate函数返回的是yyyy-MM-dd形式,因此需要在left join的时候将我的时间戳字段getTime进行转换,转换成与curDate函数返回一样的形式,否则就查不到数据;
图2
最终结果:
图3
图1
因为公司库里面所有关于时间都是直接存储时间戳,给我带来了一定的处理上的难度,幸好网上找到一个很好的想法;http://blog.csdn.net/ouyang111222/article/details/77638826
处理方式是:构建一个最近7天的结果集,没有的利用ifnull函数补0操作;
最终的sql如下:
select a.click_date,ifnull(b.count,0) as count from ( SELECT curdate() as click_date union all SELECT date_sub(curdate(), interval 1 day) as click_date union all SELECT date_sub(curdate(), interval 2 day) as click_date union all SELECT date_sub(curdate(), interval 3 day) as click_date union all SELECT date_sub(curdate(), interval 4 day) as click_date union all SELECT date_sub(curdate(), interval 5 day) as click_date union all SELECT date_sub(curdate(), interval 6 day) as click_date ) a left join ( select date(FROM_UNIXTIME(getTime/1000,'%Y%m%d')) as datetime, count(*) as count from userwechatcard group by date(FROM_UNIXTIME(getTime/1000,'%Y%m%d')) ) b on a.click_date = b.datetime;
其中有个地方需要注意一下:由于我的时间是时间戳类型,而curdate函数返回的是yyyy-MM-dd形式,因此需要在left join的时候将我的时间戳字段getTime进行转换,转换成与curDate函数返回一样的形式,否则就查不到数据;
图2
最终结果:
图3
相关文章推荐
- mysql获取当前周和当前月每天的数据或全周和全月的数据
- MySQL 对一段时间内每天数据统计案例--sql优化
- mysql 根据昨天日期获取 所有数据、本周数据、本月数据
- 使用xml来显示获取的mysql数据
- 使用R进行数据可视化套路之-多重散点图、连接Mysql获取数据
- 利用python爬虫技术获取每天每场的每位球员NBA数据以及每日范特西评分
- php 写入数据到MySQL以及从MySQL获取数据,页面出现乱码的解决方法
- 随机获取Mysql数据表的一条或多条记录
- mysql高效获取两张表共同字段的交集数据
- php7用mysqli连接mysql获取数据乱码问题
- mysql中获取一天、一周、一月时间数据的各种sql语句写法
- mysql php 查询后怎样获取数据
- [摘抄]MySQL分组后获取每个分组下的4笔数据
- 如何获取MSSQLServer,Oracel,Access,MySQL中的数据字典信息
- mysql 随机获取一张表的10条数据
- Mysql命令desc:获取数据表结构
- 2015062903 - mysql随机获取数据
- mysql中随机获取排序条件中的指定数量数据
- mysql 获取某个时间段每一天的统计数据
- MySQL -- 获取当前数据行号