hive 高级分组聚合(grouping sets cube和rollup)

本文介绍了Hive中的高级分组聚合操作,包括Grouping Sets、Cube和Rollup。通过实例展示了它们如何简化SQL语句,分别等价于不同的分组组合,并讨论了使用这些功能可能带来的优化和潜在问题,如数据膨胀。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.grouping sets

1.1

select a, b sum(c) from tbl group by a,b grouping sets((a,b))

相当于 select a,b,sum(c) from tbl group by a,b

1.2

select a,b,sum(c) from tbl group by a,b grouping sets((a,b),a)

相当于

select a,b,sum(c) from tbl group by a,b

union

select a,null ,sum(c) from tbl group by a

1.3

select a,b,sum(c) from tbl group by a,b grouping sets(a,b)

相当于

select a,null,sum(c) from tbl group by a

union

select null ,b,sum(c) from tbl group by b

1.4

select a,b,sum(c) from tbl group by a,b grouping sets((a,b),a,b,())

相当于

select a,b,sum(c) from tbl group by a,b

union

select a,null,sum(c) from tbl group by a

union

select null,b,sum(c) from tbl group by b

union

select null,null,sum(c) from tbl

2.cube 会计算所有group by 列的所有组合

select a,b,c,count(1) from tbl group by a,b,c with cub

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值