IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> Hive SQL 实际场景下计算使用时长 -> 正文阅读

[大数据]Hive SQL 实际场景下计算使用时长

多喝热水

问题背景

这篇讲一下最近的一个工作场景,需要统计用户登录时长,两个指标:每日平均单次登录时长、每日平均用户登录时长。 有的数据字段长下面这样子(这边不考虑根据不同app版本分类啊之类的 实际也做不了因为大部分是空的orz 有把一些干扰字段也列出来了):

字段名解释
id事件记录id
userid用户id
ip设备ip
triggertime事件触发时间戳
tiggertimestr事件触发时间(yyyy-mm-dd)
createtime记录创建时间戳
eventtype事件类型1,2,3,4
eventname事件名称 对应上面类型 启动app、关闭app、打开服务、关闭服务

在实际场景中,有以下几个问题

  1. 当用户打开app时是未登录状态的话,这条记录的userid为空
  2. 有userid的记录不一定有ip, 没userid的也不一定有,就很难顶
  3. 能有一个完整开启关闭记录的情况只有两种行动路径:
    • 启动App->退回到首页->关闭App
    • 启动App->打开服务->关闭服务->退回到首页->关闭App
      也就是说,我们拿到的数据集大概是11112122111222这样子,而我们要从其中找出12组合
  4. 数据源出现同一用户同一行为同一事件触发时间但是有多条记录的情况(除了createtime以外其他都一毛一样的重复数据)

数据预处理

PART1:思路

  1. 先将数据源表提取出eventtype=1或2的数据,根据userid进行分区,对triggertime进行排序处理。这边只关注有userid的记录。
  2. 假设分区中每一条记录的下一条与这一条能够形成闭环,即假设这两条记录能刚好形成12组合。

PART2 代码

create table if not exists t1 as
select userid, 
triggertimestr as start_time_str,
triggertime as start_time, 
lead(triggertime) over(partition by userid order by triggertime) as end_time,
eventtype as start_type, 
lead(eventtype) over(partition by userid order by triggertime) as end_type
from table_a
where (eventtype = '1'
or eventtype = '2')
order by userid, triggertime;

这边利用到函数lead(key, n),它输出key(要展示的字段)根据一定的规则处理后该条记录下的第n条记录,默认n=1。在该代码示例中,解释为根据userid分区且分区中根据triggertime进行上升排序,选取该条记录的下一条的trigggertime作为新字段对应的值。

输出示例如下(可以无视那个detail_time没有用的哈只是想看一下是哪个时间点的
在这里插入图片描述

计算结果

PART1:代码

-- avg_single_duration平均每日单次登录时长  
-- avg_user_duration 平均每日用户登录时长
select start_time_str, sum(duration)/count(1)/1000 as avg_single_duration, 
sum(duration)/count(distinct(userid))/1000 as avg_user_duration
from
(select *, end_time-start_time as duration
from t1
where start_type = '1'
and end_type = '2') t2
where duration <= 7200000
group by start_time_str
order by start_time_str;

在这里插入图片描述

PART2: 注意

虽然这一步很简单,只要选取我们假设的闭环记录中起始事件=1和结束事件=2的记录,再做加减乘除就可以了。另外,会发现在数据集分析中的问题4在这环节也得到了解决。但是,要注意的是,我们的匹配对的时间差可能会出现异常值(一定会出现的其实),在第一轮结果计算中发现,有的日期当日平均单次登录时长竟然达到7天,这是不可能的事情,在这边是假定计算出的登录时长超过2小时的记录我们就将其过滤掉。这个过滤界限可根据app的实际情况,不同性质的app可能不一样。

最后

使用时长是数据分析中一个蛮常见的指标,但具体还要结合实际的业务场景来分析。有的app如sns、游戏、视频,肯定是希望使用时间越长越好了。那像有的app如工具、服务预约这类型的就比较复杂,我们希望用户在使用时不需要太多学习成本,以达成更便捷的效果,又希望用户会多次使用。这时候可能要将次数、日均单次访问时长、日均用户访问时长、留存率、具体功能这些相结合来进行分析。啊就很复杂orz

另外说一点工作半年来的心得吧,不要轻易相信数据商提供的字段值含义,不要直接根据字段名上手写脚本。大部分情况下一些字段会和实际业务有关联,要考虑场景才能更好的进行分析,有的甚至数据源的设计就很有问题,于是沟通成本真的很大哈哈哈哈哈哈哈哈哈哈哈,每天卑微提问(bushi

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-08-13 12:07:06  更:2021-08-13 12:13:09 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/18 20:56:42-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码