当前位置: 首页 > article >正文

经典sql题(六)查找用户每月累积访问次数

使用聚合开窗查找用户每月累积访问次数,首先介绍一下使用 GROUP BY和开窗的区别

GROUP BY
  • 行数变化:使用 GROUP BY 后,原始数据会按指定列进行分组,结果中每组只保留一行,因此行数通常减少。
  • 作用:适用于需要对数据进行汇总的场景,如计算总和、平均值等。
  • 示例:如果有多个用户的访问记录,通过 GROUP BY 可以将每个用户每月的访问次数汇总为一行。
窗口函数
  • 行数变化:窗口函数在计算时不改变原始数据的行数,即每条原始记录依然保留。
  • 作用:适用于需要在保留详细数据的同时进行累积计算、排名等操作。
  • 示例:在按月汇总用户访问数据的同时,通过窗口函数增加一列显示累计访问次数,每月的详细记录依然存在。

示例数据

假设 test 表有如下数据:

user_idvisit_datevisit_count
12023-01-05 10:30:0010
12023-01-15 15:45:0020
12023-02-10 12:00:0015
22023-01-07 09:00:005
22023-02-11 14:30:0010
32023-01-20 11:00:008
32023-02-05 16:30:0012
42023-01-25 14:00:007
42023-02-15 09:15:009
52023-01-10 13:30:006
52023-02-20 16:45:0011

第一步:提取年月并计算每月访问次数

我们首先提取出每条记录的年月,并计算每个用户每月的访问次数:

SELECT
    user_id,
    DATE_FORMAT(visit_date, '%Y-%m') AS month_id,
    SUM(visit_count) AS visit_cnt_lm
FROM
    test
GROUP BY
    user_id,
    month_id;
结果(子查询结果)
user_idmonth_idvisit_cnt_lm
12023-0130
12023-0215
22023-015
22023-0210
32023-018
32023-0212
42023-017
42023-029
52023-016
52023-0211

第二步:计算访问次数的累计值

然后,我们使用窗口函数为每个用户计算访问次数的累计值:

SELECT
    user_id,
    month_id,
    visit_cnt_lm,
    SUM(visit_cnt_lm) OVER (PARTITION BY user_id ORDER BY month_id) AS visit_cnt_td
FROM (
    SELECT
        user_id,
        DATE_FORMAT(visit_date, '%Y-%m') AS month_id,
        SUM(visit_count) AS visit_cnt_lm
    FROM
        test
    GROUP BY
        user_id,
        month_id
) AS t2;
结果(最终结果)
user_idmonth_idvisit_cnt_lmvisit_cnt_td
12023-013030
12023-021545
22023-0155
22023-021015
32023-0188
32023-021220
42023-0177
42023-02916
52023-0166
52023-021117

步骤

  1. 提取年月并计算访问次数

    • 查询:使用 DATE_FORMAT 提取年月,并汇总每个用户每月的访问次数。
    • 结果表:显示用户、月份及其访问次数。
  2. 计算访问次数的累计值

    • 查询:使用窗口函数计算每个用户的访问次数累计值。
    • 最终结果:展示每个用户每月的访问次数及其累计值。

解析

  • 提取年月:使用 DATE_FORMAT 方法从完整日期中提取年月。

  • 汇总访问次数:利用 SUM(visit_count) 按用户和月份分组汇总数据。

  • 计算累计值:通过窗口函数 SUM() OVER 按用户分区、按月份排序,计算每个用户的访问次数累计值。

  • SUM(visit_cnt_lm) OVER (PARTITION BY user_id ORDER BY month_id) 计算每个用户按照月份的累计访问次数。

  • PARTITION BY user_id 按用户分区,ORDER BY month_id 按月份排序。


http://www.kler.cn/a/309271.html

相关文章:

  • 【嵌入式开发】单片机CAN配置详解
  • 贪心算法入门(二)
  • Pycharm PyQt5 环境搭建创建第一个Hello程序
  • 常用的Anaconda Prompt命令行指令
  • 时序数据库TimescaleDB安装部署以及常见使用
  • D67【python 接口自动化学习】- python基础之数据库
  • Artcam中文版安装包+教程网盘资源下载
  • C语言深入理解指针(二)
  • linux-虚拟化与容器化-容器化
  • gitlab/极狐-离线包下载地址
  • 学习记录:js算法(三十三):LRU 缓存
  • 音频左右声道数据传输_2024年9月6日
  • sqli-labs靶场自动化利用工具——第2关
  • C++系列-STL中find相关的算法
  • 联合仿真(FMI,FMU)资料收集
  • 【mysql】逻辑运算符
  • QT实现TCP协议
  • 『功能项目』第二职业法师的平A【57】
  • nlohmann::json中有中文时调用dump转string抛出异常的问题
  • C++:类和对象全解
  • 【C++】日期类基础题
  • 笔记整理—内核!启动!—kernel部分(6)buxybox详解
  • 视觉检测中的深度学习应用
  • vue3 ref的用法及click事件的说明
  • 使用 uni-app 开发微信小程序的详细指南
  • go mod文件为啥又两个require