2023.11.15-hivesql之炸裂函数explode练习

把一个容器的多个数据炸裂出单独展示: explode(容器)

需求:将NBA总冠军球队数据使用explode进行拆分,并且根据夺冠年份进行倒序排序。

1.建表

sql 复制代码
--step1:建表
create table the_nba_championship(
           team_name string,
           champion_year array<string>
) row format delimited
fields terminated by ','
collection items terminated by '|';

2.加载数据

sql 复制代码
load data  inpath '/input/The_NBA_Championship.txt' into table the_nba_championship;

3.验证数据

sql 复制代码
p3:验证数据
select * from the_nba_championship;

可以使用order by,但效率太低

sql 复制代码
--只查询冠军年份,降序排序
select explode(champion_year) as champ
from the_nba_championship order by champ ;  --order by 太占用资源,效率低

使用炸裂函数,配合侧视图,制作新表

sql 复制代码
-- 将NBA总冠军球队数据使用explode进行拆分,并且根据夺冠年份进行倒序排序。
--先将冠军年各个炸出来
select explode(champion_year) from the_nba_championship;

--再将炸出来的结果用侧视图保存,和原表的球队名字拼起来

with nba as 
    (select team_name, c.champ_year_explode
    from the_nba_championship
    lateral view explode(champion_year) c as champ_year_explode 
    --冠军年份炸开后,存到虚拟表c,并起了个字段名,与原表进行拼接.
    --并将拼接完成的表起了个别名,作为排序查询的准备    
)
select * from nba order by champ_year_explode desc ;

结果

相关推荐
bukeyiwanshui1 分钟前
20260414 正则表达式及shell三剑客
数据库·mysql·正则表达式
cyber_两只龙宝2 分钟前
【Oracle】Oracle之SQL中的单行函数
linux·运维·数据库·sql·云原生·oracle
Trouvaille ~26 分钟前
【MySQL篇】内外连接:多表关联的完整指南
android·数据库·mysql·面试·后端开发·dql·内外连接
geovindu1 小时前
go: Model,Interface,DAL ,Factory,BLL using mysql
开发语言·mysql·设计模式·golang·软件构建
人工干智能1 小时前
科普:pandas 中的类 SQL语句:transaction.groupby(“card_id“)[‘purchase_day‘].diff()
数据库·sql·pandas
梦想与想象-广州大智汇1 小时前
MySQL 同步数据到 ClickHouse 方案对比分析
数据库·mysql·clickhouse
yuezhilangniao1 小时前
centos7安装mysql57- 2026整理 mysql5.7.44
mysql
Bohemian—Rhapsody2 小时前
银河麒麟(ky10.aarch64)操作系统安装部署mysql5.7.26
mysql·arm
tian_jiangnan2 小时前
flink mysql集群增删改查
大数据·mysql·flink
dualven_in_csdn2 小时前
EMQX 开启 **MySQL + password_based** 认证
android·数据库·mysql