Mysql如何查询近30天活跃用户数

 更新时间:2024年08月01日 10:33:32   作者:@See you later  
这篇文章主要介绍了Mysql查询近30天活跃用户数,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧

思路:

题目要求:统计截至 2019-07-27(包含2019-07-27),近 30 天的每日活跃用户数(当天只要有一条活动记录,即为活跃用户)

要计算日期之间的天数,这时就需要用到DATEDIFF函数

DATEDIFF(date1,date2):返回date1 - date2的日期间隔天数

把在时间要求内的筛选出来,再进行 用户id 分组,最后统计用户个数(去重后的)

解题过程:

先对日期进行筛选

SELECT *
FROM activity
WHERE DATEDIFF('2019-07-27',activity_date) BETWEEN 0 AND 29

然后再日期进行分组,计算用户id,这时需要对用户id进行去重,若不去重,则会出现以下结果

SELECT activity_date, COUNT(user_id)
FROM activity
WHERE DATEDIFF('2019-07-27',activity_date) BETWEEN 0 AND 29
GROUP BY activity_date 

所以需要对用户id进行去重处理(COUNT(DISTINCT user_id)保证每个用户不相同(或者说重复出现)

踩了个坑:

WHERE DATEDIFF('2019-07-27',activity_date) BETWEEN 0 AND 29
GROUP BY activity_date

GROUP BY activity_date
HAVING DATEDIFF('2019-07-27',activity_date) BETWEEN 0 AND 29

提出问题,这两个mysql语句都可以执行成功,但两者一点问题都没有嘛?

一个先过滤后分组,另一个先分组后过滤。按理说没毛病啊

但是结果却是:

  • 第一个查询是正确的,因为它使用WHERE子句来过滤日期范围,然后使用GROUP BY和COUNT(DISTINCT user_id)来统计每日活跃用户数。
  • 第二个查询错误地将日期范围过滤放在了HAVING子句中,而没有使用聚合函数,这不符合SQL语法。
  • 正确的做法是在WHERE子句中指定日期范围过滤条件,然后使用GROUP BY进行分组统计。

注意:HAVING子句不能独立于聚合函数使用来过滤原始数据

更多关于聚合函数的要点可以查看MySQL零散拾遗(四)借这个案例把里面的要点进行更进一步的阐述说明。

Code

踩坑了

SELECT activity_date day, COUNT(DISTINCT user_id) active_users 
FROM activity
WHERE DATEDIFF('2019-07-27',activity_date) BETWEEN 0 AND 29
GROUP BY activity_date 

到此这篇关于Mysql查询近30天活跃用户数的文章就介绍到这了,更多相关Mysql查询活跃用户数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • mysql小版本升级实战小结

    mysql小版本升级实战小结

    本文主要介绍了mysql小版本升级实战小结,包括环境检查、数据备份、服务停止、选择二进制或RPM安装方式、配置调整、服务重启及验证,感兴趣的可以了解一下
    2025-07-07
  • mysql drop database删除数据库命令实例讲解

    mysql drop database删除数据库命令实例讲解

    这篇文章主要介绍了mysql drop database删除数据库命令实例讲解的相关资料,需要的朋友可以参考下
    2016-09-09
  • MySQL隐式转换造成索引失效的解决办法

    MySQL隐式转换造成索引失效的解决办法

    数据库优化是一个任重而道远的任务,想要做优化必须深入理解数据库的各种特性,在开发过程中我们经常会遇到一些原因很简单但造成的后果却很严重的疑难杂症,这类问题往往还不容易定位,本文将给大家介绍MySQL隐式转换造成索引失效的解决办法,需要的朋友可以参考下
    2025-02-02
  • 提高MySQL深分页查询效率的三种方案

    提高MySQL深分页查询效率的三种方案

    这篇文章介绍了提高MySQL深分页查询效率的三种方案,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-07-07
  • MySQL Slave 触发 oom-killer解决方法

    MySQL Slave 触发 oom-killer解决方法

    这篇文章主要介绍了MySQL Slave 触发 oom-killer解决方法,需要的朋友可以参考下
    2016-07-07
  • Linux下mysql5.6.33安装配置教程

    Linux下mysql5.6.33安装配置教程

    这篇文章主要为大家详细介绍了Linux下mysql5.6.33安装配置方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-04-04
  • Mysql单库迁移的操作方法

    Mysql单库迁移的操作方法

    这篇文章主要介绍了Mysql单库迁移的相关知识,包括导出数据库文件,上传至目标机器的操作方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • node 多种方法连接mysql数据库(最新推荐)

    node 多种方法连接mysql数据库(最新推荐)

    mysql是一个流行的第三方模块,可以通过npm安装,在Node.js 中,有多种方法可以连接 MySQL 数据库,本文通过实例代码讲解node 多种方法连接mysql数据库的示例代码,感兴趣的朋友跟随小编一起看看吧
    2023-07-07
  • Mysql 5.6.24安装实例教程

    Mysql 5.6.24安装实例教程

    这篇文章主要介绍了Mysql 5.6.24安装实例教程,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-12-12
  • MySQL笔记之函数查询的使用

    MySQL笔记之函数查询的使用

    本篇文章介绍了mysql中函数查询的使用。需要的朋友参考下
    2013-05-05

最新评论