ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

MYSQL 实现查询一周内每天日志数量(详细分析和讲解流程)

2021-09-30 11:03:05  阅读:330  来源: 互联网

标签:SUB INTERVAL item CURDATE MYSQL DATE 详细分析 日志 SELECT


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)

 上述代码有问题可在下面评论留言哦!感谢支持!

标签:SUB,INTERVAL,item,CURDATE,MYSQL,DATE,详细分析,日志,SELECT
来源: https://blog.csdn.net/m0_43432638/article/details/120562134

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有