MYSQL 实现查询一周内每天日志数量(详细分析和讲解流程)
2021/9/30 19:14:57
本文主要是介绍MYSQL 实现查询一周内每天日志数量(详细分析和讲解流程),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1、需求说明
需要做个首页将系统日志前一周内的每天的日志数量显示成折线图表中:
我们需要通过sql语句查询系统表的一周前的每日数据量,查询结果的预期应该是这样的:
2、遇到问题
下面是第一个实现的版本,但是执行结果并不是我们的预期结果,因为会存在一个问题,假设系统日志在一周内的某几天没有产生数据,那么久会变成下面这个结果:
SELECT DATE_FORMAT(create_time,'%Y-%m-%d') days, COUNT(*) COUNT FROM ( SELECT * FROM sys_log WHERE DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= DATE(create_time) ) AS test GROUP BY days;
3、问题解决
首先我们需要创建一个一周内的时间虚表,然后通过left join左连接上面sql的查询结果,并注意如果为空的时候应该使用IFNULL(a.COUNT,0)去处理:
SELECT b.item,IFNULL(a.COUNT,0) AS VALUE FROM ( SELECT CURDATE() AS item UNION ALL SELECT DATE_SUB(CURDATE(), INTERVAL 1 DAY) AS item UNION ALL SELECT DATE_SUB(CURDATE(), INTERVAL 2 DAY) AS item UNION ALL SELECT DATE_SUB(CURDATE(), INTERVAL 3 DAY) AS item UNION ALL SELECT DATE_SUB(CURDATE(), INTERVAL 4 DAY) AS item UNION ALL SELECT DATE_SUB(CURDATE(), INTERVAL 5 DAY) AS item UNION ALL SELECT DATE_SUB(CURDATE(), INTERVAL 6 DAY) AS item ) b LEFT JOIN ( SELECT DATE_FORMAT(create_time,'%Y-%m-%d') days, COUNT(*) COUNT FROM (SELECT * FROM sys_log WHERE DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= DATE(create_time)) GROUP BY days ) AS a ON (b.item = a.days)
上述代码有问题可在下面评论留言哦!感谢支持!
这篇关于MYSQL 实现查询一周内每天日志数量(详细分析和讲解流程)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-29阿里 Canal 实时同步 MySQL 增量数据至 ClickHouse 数据库
- 2024-05-24在Linux下管理MySQL的大小写敏感性
- 2024-04-26MySQL查出时间比实际晚8小时的解决方案
- 2024-04-01JPA不识别MySQL的枚举类型
- 2024-03-30mysql数据库表卡死解决方法
- 2024-03-15MySQL多数据源笔记5-ShardingJDBC实战
- 2024-03-11natural join mysql
- 2024-03-11关于VS2017,VS2015 中利用 EF使用Mysql 不显示数据源问题解决方案
- 2024-02-26mysql 阿里云xb后缀备份文件恢复-icode9专业技术文章分享
- 2024-02-22docker mysql 5.7