Hive3:简单ETL实操案例

一、ETL概念简介

ETL:

E,Extract,抽取

T,Transform,转换

L,Load,加载
从A抽取数据(E),进行数据转换过滤(T),将结果加载到B(L),就是ETL

二、情景描述

聊天平台每天都会有大量的用户在线,会出现大量的聊天数据,通过对聊天数据的统计分析,可以更好的对用户构建精准的用户画像,为用户提供更好的服务以及实现高ROI的平台运营推广,给公司的发展决策提供精确的数据支撑。

我们将基于一个社交平台App的用户数据,完成相关指标的统计分析并结合BI工具对指标进行可视化展现。

三、数据内容

数据大小:30万条数据

列分隔符:Hive默认分隔符'\001'

数据字典及样例数据

四、具体实现

1、数据准备

1、建库

sql 复制代码
--如果数据库已存在就删除
drop database if exists db_msg cascade ;
--创建数据库
create database db_msg ;
--切换数据库
use db_msg ;
--列举数据库
show databases ;

2、建表

sql 复制代码
-- 如果表已存在就删除
drop table if exists db_msg.tb_msg_source ;
-- 建表
create table db_msg.tb_msg_source(
    msg_time string comment "消息发送时间",
    sender_name string comment "发送人昵称",
    sender_account string comment "发送人账号",
    sender_sex string comment "发送人性别",
    sender_ip string comment "发送人ip地址",
    sender_os string comment "发送人操作系统",
    sender_phonetype string comment "发送人手机型号",
    sender_network string comment "发送人网络类型",
    sender_gps string comment "发送人的GPS定位",
    receiver_name string comment "接收人昵称",
    receiver_ip string comment "接收人IP",
    receiver_account string comment "接收人账号",
    receiver_os string comment "接收人操作系统",
    receiver_phonetype string comment "接收人手机型号",
    receiver_network string comment "接收人网络类型",
    receiver_gps string comment "接收人的GPS定位",
    receiver_sex string comment "接收人性别",
    msg_type string comment "消息类型",
    distance string comment "双方距离",
    message string comment "消息内容"
);

3、加载数据

sql 复制代码
load data  inpath '/chatdemo/data/chat_data-30W.csv' overwrite into table tb_msg_source;

检查数据加载情况

sql 复制代码
SELECT *  FROM tb_msg_source tablesample(100 rows);

2、ETL数据清洗

1、数据问题

问题1

当前数据中,有一些数据的字段为空,不是合法数据

sql 复制代码
select
msg_time,
sender_name,
sender_gps
from db_msg.tb_msg_source
where length(sender_gps) = 0
limit 10;

问题2

需求中,需要统计每天、每个小时的消息量,但是数据中没有天和小时字段,只有整体时间字段,不好处理

sql 复制代码
select msg_time from db_msg.tb_msg_source limit 10;

问题3

需求中,需要对经度和维度构建地区的可视化地图,但是数据中GPS经纬度为一个字段,不好处理

sql 复制代码
select sender_gps from db_msg.tb_msg_source limit 10;

2、数据清洗

需求1

对字段为空的不合法数据进行过滤

where过滤
需求2

通过时间字段构建天和小时字段

date hour函数
需求3

从GPS的经纬度中提取经度和维度

split函数
需求4

将ETL以后的结果保存到一张新的Hive表中


先创建ETL结果保存表

sql 复制代码
create table db_msg.tb_msg_etl(
    msg_time string comment "消息发送时间",
    sender_name string comment "发送人昵称",
    sender_account string comment "发送人账号",
    sender_sex string comment "发送人性别",
    sender_ip string comment "发送人ip地址",
    sender_os string comment "发送人操作系统",
    sender_phonetype string comment "发送人手机型号",
    sender_network string comment "发送人网络类型",
    sender_gps string comment "发送人的GPS定位",
    receiver_name string comment "接收人昵称",
    receiver_ip string comment "接收人IP",
    receiver_account string comment "接收人账号",
    receiver_os string comment "接收人操作系统",
    receiver_phonetype string comment "接收人手机型号",
    receiver_network string comment "接收人网络类型",
    receiver_gps string comment "接收人的GPS定位",
    receiver_sex string comment "接收人性别",
    msg_type string comment "消息类型",
    distance string comment "双方距离",
    message string comment "消息内容",
    msg_day string comment "消息日",
    msg_hour string comment "消息小时",
    sender_lng double comment "经度",
    sender_lat double comment "纬度"
);

整理清洗SQL,并存入ETL

sql 复制代码
 INSERT OVERWRITE TABLE db_msg.tb_msg_etl
 SELECT 
	*, 
	DATE(msg_time) AS msg_day, 
	HOUR(msg_time) AS msg_hour, 
	SPLIT(sender_gps, ',')[0] AS sender_lng, 
	SPLIT(sender_gps, ',')[1] AS sender_lat
FROM db_msg.tb_msg_source
WHERE LENGTH(sender_gps) > 0;

查看结果

sql 复制代码
select    msg_time, msy_day, msg_hour, sender_gps, sender_lng, sender_lat from db_msg.tb_msg_etl limit 10;

3、总结

这里是个简单的ETL案例。

做过Java Web的,应该都有过这样的经历,直接SQL查询出想要的结果,展示到页面

此时,会不会觉得这种ETL操作是多于的?

但是,对于大量数据,每次聚合查询,会导致页面报表加载效率降低。

所以,需要大数据离线处理好数据结果,在通过简单的查询语句,返回给页面。

这样,就可以改善用户体验。

另外,在真实的大数据ETL过程中,不会仅仅依靠SQL来实现,肯定需要很多的第三方中间件。

比如

可能用到logstash、sqoop、kafka等。

还有可能自己编写Java程序包。

3、指标计算

统计今日总消息量

sql 复制代码
--保存结果表
CREATE TABLE IF NOT EXISTS tb_rs_total_msg_cnt 
COMMENT "每日消息总量" AS 
SELECT 
    msg_day, 
    COUNT(*) AS total_msg_cnt 
FROM db_msg.tb_msg_etl 
GROUP BY msg_day;

统计今日每小时消息量、发送和接收用户数

sql 复制代码
--保存结果表
CREATE TABLE IF NOT EXISTS tb_rs_hour_msg_cnt 
COMMENT "每小时消息量趋势" AS  
SELECT  
    msg_hour, 
    COUNT(*) AS total_msg_cnt, 
    COUNT(DISTINCT sender_account) AS sender_user_cnt, 
    COUNT(DISTINCT receiver_account) AS receiver_user_cnt
FROM db_msg.tb_msg_etl GROUP BY msg_hour;

统计今日各地区发送消息数据量

sql 复制代码
CREATE TABLE IF NOT EXISTS tb_rs_loc_cnt
COMMENT '今日各地区发送消息总量' AS 
SELECT 
    msg_day,  
    sender_lng, 
    sender_lat, 
    COUNT(*) AS total_msg_cnt 
FROM db_msg.tb_msg_etl
GROUP BY msg_day, sender_lng, sender_lat;

统计今日发送消息和接收消息的用户数

sql 复制代码
--保存结果表
CREATE TABLE IF NOT EXISTS tb_rs_user_cnt
COMMENT "今日发送消息人数、接受消息人数" AS
SELECT 
msg_day, 
COUNT(DISTINCT sender_account) AS sender_user_cnt, 
COUNT(DISTINCT receiver_account) AS receiver_user_cnt
FROM db_msg.tb_msg_etl
GROUP BY msg_day;

统计今日发送消息最多的Top10用户

sql 复制代码
--保存结果表
CREATE TABLE IF NOT EXISTS db_msg.tb_rs_s_user_top10
COMMENT "发送消息条数最多的Top10用户" AS
SELECT 
    sender_name AS username, 
    COUNT(*) AS sender_msg_cnt 
FROM db_msg.tb_msg_etl 
GROUP BY sender_name 
ORDER BY sender_msg_cnt DESC 
LIMIT 10;

统计今日接收消息最多的Top10用户

sql 复制代码
CREATE TABLE IF NOT EXISTS db_msg.tb_rs_r_user_top10
COMMENT "接收消息条数最多的Top10用户" AS
SELECT 
receiver_name AS username, 
COUNT(*) AS receiver_msg_cnt 
FROM db_msg.tb_msg_etl 
GROUP BY receiver_name 
ORDER BY receiver_msg_cnt DESC 
LIMIT 10;

统计发送人的手机型号分布情况

sql 复制代码
CREATE TABLE IF NOT EXISTS db_msg.tb_rs_sender_phone
COMMENT "发送人的手机型号分布" AS
SELECT 
    sender_phonetype, 
    COUNT(sender_account) AS cnt 
FROM db_msg.tb_msg_etl 
GROUP BY sender_phonetype;

统计发送人的设备操作系统分布情况

sql 复制代码
--保存结果表
CREATE TABLE IF NOT EXISTS db_msg.tb_rs_sender_os
COMMENT "发送人的OS分布" AS
SELECT
    sender_os, 
    COUNT(sender_account) AS cnt 
FROM db_msg.tb_msg_etl 
GROUP BY sender_os
相关推荐
计算机学姐2 小时前
基于Python的电影票房数据分析系统
开发语言·vue.js·hive·后端·python·spark·django
Casual_Lei2 小时前
Sqoop
hive·hadoop·sqoop
Casual_Lei5 小时前
Hadoop Pig
大数据·hadoop·分布式
MinIO官方账号6 小时前
对象存储上的数据库--新常态
大数据·数据库·hadoop·分布式·架构·kafka
大数据深度洞察7 小时前
Hadoop压缩技术与Hive文件格式详解
大数据·数据仓库·hive·hadoop·sql
我的K84098 小时前
数据倾斜问题
大数据·hadoop·分布式
isNotNullX9 小时前
Hadoop如何进行分布式存储和处理大数据?
大数据·hadoop·分布式
尘世壹俗人9 小时前
Hive任务优化参数整理
数据仓库·hive·hadoop
JavaShooter10 小时前
argodb自定义函数读取hdfs文件的注意点,避免FileSystem已关闭异常
大数据·hadoop·hdfs
lisacumt13 小时前
【jvm】记一次hive堆heap内存溢出的排查
jvm·hive