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行列转换 -> 正文阅读

[大数据]hive行列转换

1.一行转多行

--数据
vi test.txt
a   b   1,2,3
c   d   4,5,6

-- 建表
create table test(
col1 string,
col2 string,
col3 string
)
comment'一行转多行测试表'
row format delimited fields terminated by '\t'
stored as textfile;

-- 加载数据
load data local inpath '/root/col_to_row.txt' into table test;
+-----------------------+-----------------------+-----------------------+--+
| test.col1             | test.col2             | test.col3             |
+-----------------------+-----------------------+-----------------------+--+
| a                     | b                     | 1,2,3                 |
| c                     | d                     | 4,5,6                 |
+-----------------------+-----------------------+-----------------------+--+

-- 计算
select
col1,
col2,
tmp.col3
from test
lateral view explode(split(col3,',')) tmp as col3
;
+-------+-------+-----------+--+
| col1  | col2  | tmp.col3  |
+-------+-------+-----------+--+
| a     | b     | 1         |
| a     | b     | 2         |
| a     | b     | 3         |
| c     | d     | 4         |
| c     | d     | 5         |
| c     | d     | 6         |
+-------+-------+-----------+--+

create table array_to_row_test(
col1 string,
col2 string,
col3 array<string>
)
comment'一行转多行测试表'
row format delimited fields terminated by '\t'
collection items terminated by ','
stored as textfile;

select * from array_to_row_test;
+-------------------------+-------------------------+-------------------------+--+
| array_to_row_test.col1  | array_to_row_test.col2  | array_to_row_test.col3  |
+-------------------------+-------------------------+-------------------------+--+
| a                       | b                       | ["1","2","3"]           |
| c                       | d                       | ["4","5","6"]           |
+-------------------------+-------------------------+-------------------------+--+

select
col1,
col2,
col4
from array_to_row_test
lateral view explode(col3) tmp as col4
;
+-------+-------+-------+--+
| col1  | col2  | col4  |
+-------+-------+-------+--+
| a     | b     | 1     |
| a     | b     | 2     |
| a     | b     | 3     |
| c     | d     | 4     |
| c     | d     | 5     |
| c     | d     | 6     |
+-------+-------+-------+--+

2.多行转一行

源表:
+---------------+---------------+---------------+--+
| test2.field1  | test2.field2  | test2.field3  |
+---------------+---------------+---------------+--+
| a             | b             | 1             |
| a             | b             | 2             |
| a             | b             | 3             |
| c             | d             | 4             |
| c             | d             | 5             |
| c             | d             | 6             |
+---------------+---------------+---------------+--+

目标表:
+---------+----------+--+
| field1  |  field3  |
+---------+----------+--+
| a       | [1,2,3]  |
| c       | [4,5,6]  |
+---------+----------+--+
函数介绍:
-- 将分组内某个字段的所有值收集起来变成集合或者数组(set去重,list不去重)
collect_set(字段)
collect_list(字段)
-- 同行字段

计算:
select
field1,
field2,
collect_set(field3) as field3
from test2
group by field1,field2
;
+---------+---------+----------+--+
| field1  | field2  |  field3  |
+---------+---------+----------+--+
| a       | b       | [1,2,3]  |
| c       | d       | [4,5,6]  |
+---------+---------+----------+--+
-- 合并多个字符串
concat(字段,字段,字段...)
concat_ws(分割符,字段1,字段2...)
select
field1,
field2,
concat_ws(',',collect_set(concat(field3,''))) as field3
from test2
group by field1,field2
;
+---------+---------+---------+--+
| field1  | field2  | field3  |
+---------+---------+---------+--+
| a       | b       | 1,2,3   |
| c       | d       | 4,5,6   |
+---------+---------+---------+--+

3.行转列

建表:
create table student_score(s_id int,s_name string,s_sub string,s_score bigint);
insert into student_score values
(1,'张三','数学',90),
(2,'张三','语文',85),
(3,'张三','英语',92),
(4,'李四','数学',88),
(5,'李四','语文',91),
(6,'李四','英语',99),
(7,'王五','数学',100),
(8,'王五','语文',82),
(9,'王五','英语',88);

源表:
+---------------------+-----------------------+----------------------+------------------------+--+
| student_score.s_id  | student_score.s_name  | student_score.s_sub  | student_score.s_score  |
+---------------------+-----------------------+----------------------+------------------------+--+
| 1                   | 张三                    | 数学                   | 90                     |
| 2                   | 张三                    | 语文                   | 85                     |
| 3                   | 张三                    | 英语                   | 92                     |
| 4                   | 李四                    | 数学                   | 88                     |
| 5                   | 李四                    | 语文                   | 91                     |
| 6                   | 李四                    | 英语                   | 99                     |
| 7                   | 王五                    | 数学                   | 100                    |
| 8                   | 王五                    | 语文                   | 82                     |
| 9                   | 王五                    | 英语                   | 88                     |
+---------------------+-----------------------+----------------------+------------------------+--+

目标表:
+---------+-----+------+-----+--+
| 姓名      | 语文  |  数学  | 英语  |
+---------+-----+------+-----+--+
| 张三      | 85  | 90   | 92  |
| 李四      | 91  | 88   | 99  |
| 王五      | 82  | 100  | 88  |
+---------+-----+------+-----+--+

计算:
select
s_name as `姓名`,
max(case when s_sub='语文' then s_score else 0 end) as `语文`,
max(case when s_sub='数学' then s_score else 0 end) as `数学`,
max(case when s_sub='英语' then s_score else 0 end) as `英语`
from student_score
group by s_name;
+---------+-----+------+-----+--+
| 姓名      | 语文  |  数学  | 英语  |
+---------+-----+------+-----+--+
| 张三      | 85  | 90   | 92  |
| 李四      | 91  | 88   | 99  |
| 王五      | 82  | 100  | 88  |
+---------+-----+------+-----+--+

4.列转行

建表:
create table student_score2 as
select
s_name as `姓名`,
max(case when s_sub='语文' then s_score else 0 end) as `语文`,
max(case when s_sub='数学' then s_score else 0 end) as `数学`,
max(case when s_sub='英语' then s_score else 0 end) as `英语`
from student_score
group by s_name;

源表:
+---------+-----+------+-----+--+
| 姓名      | 语文  |  数学  | 英语  |
+---------+-----+------+-----+--+
| 张三      | 85  | 90   | 92  |
| 李四      | 91  | 88   | 99  |
| 王五      | 82  | 100  | 88  |
+---------+-----+------+-----+--+

目标表:
+-----------------------+----------------------+------------------------+--+
| student_score.s_name  | student_score.s_sub  | student_score.s_score  |
+-----------------------+----------------------+------------------------+--+
| 张三                    | 数学                   | 90                     |
| 张三                    | 语文                   | 85                     |
| 张三                    | 英语                   | 92                     |
| 李四                    | 数学                   | 88                     |
| 李四                    | 语文                   | 91                     |
| 李四                    | 英语                   | 99                     |
| 王五                    | 数学                   | 100                    |
| 王五                    | 语文                   | 82                     |
| 王五                    | 英语                   | 88                     |
+-----------------------+----------------------+------------------------+--+

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

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 15:01:52-

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