前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mysql 实现统计最近7天用户登录人数 人数为空则填充为0

Mysql 实现统计最近7天用户登录人数 人数为空则填充为0

作者头像
Lcry
发布2022-11-29 19:16:54
1.4K0
发布2022-11-29 19:16:54
举报
文章被收录于专栏:Lcry个人博客

最近在做毕设,然后做统计功能,简单的统计一下用户近7天的登录情况,数据库有一张t_log日志表进行记录登录,但是会遇到偶尔中间一天没有登录人数,那么要显示日期,人数填充为0,于是进行了实现了。

获取最近7天的SQL:

代码语言:javascript
复制
select a.date
from (
    SELECT curdate() as date
    union all
    SELECT date_sub(curdate(), interval 1 day) as date
    union all
    SELECT date_sub(curdate(), interval 2 day) as date
    union all
    SELECT date_sub(curdate(), interval 3 day) as date
    union all
    SELECT date_sub(curdate(), interval 4 day) as date
    union all
    SELECT date_sub(curdate(), interval 5 day) as date
    union all
    SELECT date_sub(curdate(), interval 6 day) as date
) a 

然后去关联业务表,进行筛选,ifnull 函数判断是否为空,最终SQL如下:

代码语言:javascript
复制
select a.date,ifnull(b.count,0) as count
from (
    SELECT curdate() as date
    union all
    SELECT date_sub(curdate(), interval 1 day) as date
    union all
    SELECT date_sub(curdate(), interval 2 day) as date
    union all
    SELECT date_sub(curdate(), interval 3 day) as date
    union all
    SELECT date_sub(curdate(), interval 4 day) as date
    union all
    SELECT date_sub(curdate(), interval 5 day) as date
    union all
    SELECT date_sub(curdate(), interval 6 day) as date
) a LEFT join 
(select DATE_FORMAT(create_time,'%Y-%m-%d') days,count(*) count from t_log group by days) b
on a.date=b.days order by a.date 

其中 t_log 为日志表,create_time是其中一个字段

参考链接: https://blog.csdn.net/ljxbbss/article/details/78028424 https://www.cnblogs.com/phperlinxinlan/p/10528859.html https://blog.csdn.net/LONG_Yi_1994/article/details/85705047 https://blog.csdn.net/dmw412724/article/details/95318091

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019-07-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 获取最近7天的SQL:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档