MySQL和Hive中的行转列、列转行

水善利万物而不争,处众人之所恶,故几于道💦

文章目录

MySQL

1.行转列

把多行转成列。直接group,sum(if())

2.列转行


Hive

1.行转列

sql 复制代码
select 
	name,
	sum(if(km='shuxue',cj,0)) shuxue,
	sum(if(km='yuwen',cj,0)) yuwen,
	sum(if(km='huaxue',cj,0)) huaxue 
from hzl 
group by name

2.列转行

(1)侧窗

hive中除了可以用常规的union all 外,还可以用侧窗

sql 复制代码
-- 侧窗写法
select 
	name,
	km,
	cj 
from lzh2 
	lateral view 
	explode(map('yuwen',yuwen,'shuxue',shuxue,'huaxue',huaxue)) tmp as km,cj;
(2)union
sql 复制代码
-- 常规写法
select name,'shuxue' km,shuxue cj from lzh2 
union all 
select name,'yuwen',yuwen from lzh2 
union all 
select name,'huaxue',huaxue from lzh2;
相关推荐
大空大地20262 分钟前
Entity Framework
数据库
王仲肖7 分钟前
PostgreSQL 事务 ID 年龄增长与冻结机制分析
数据库·postgresql
好家伙VCC13 分钟前
**CQRS模式实战:用Go语言构建高并发读写分离架构**在现代分布式系统中,随着业务复杂度的提升和用户量的增长,传统的单数据库模型逐
java·数据库·python·架构·golang
不剪发的Tony老师20 分钟前
pgmetrics:一款免费开源的PostgreSQL统计指标采集工具
数据库·postgresql
@insist12321 分钟前
数据库系统工程师-必知的系统开发知识
数据库·oracle·软考·数据库系统工程师·软件水平考试
星辰_mya22 分钟前
数据库运维与数据安全:备份恢复、日志分析与故障排查
运维·数据库·后端·面试·架构师
RisunJan22 分钟前
Linux命令-mysqladmin(MySQL服务器管理客户端)
linux·服务器·mysql
|华|26 分钟前
MySQL高可用详细解析
数据库·mysql
白露与泡影27 分钟前
InnoDB、PostgreSQL 与存算分离:刷脏保序的抉择
数据库·postgresql
无极低码29 分钟前
windows 程连接 Oracle 报 ORA-12541
数据库·windows·oracle