hive sql求多个字段的最小值和最大值的办法

2019/04/25 09:57
阅读数 2.5K

 

1. 准备数据表test2

create table test2(
a int,
b int,
c int,
d int,
e int);

2. 准备2条数据

insert into table test2 values(5,1,3,8,6);
insert into table test2 values(6,2,5,11,9);

查询显示如下:

3. 现在要求出a,b,c,d,e 5个字段中每行的最大值和最小值。

  虽然hive中有min和max,但是那是求某列字段的最小值和最大值,在这里行不通。接下来使用hive中的数组排序方法来求解。

  思路: 先将字段合并到数组里面,然后使用数组排序函数。

select sort_array(array(a,b,c,d,e)) from test2;

结果显示如下:

这样,第一个就是最小值,最后一个就是最大值。完整代码如下:

select arr[0] as min_val, arr[4] as max_val 
from(
     select sort_array(array(a,b,c,d,e)) arr 
     from test2
)a;

 最终结果如下:

 

展开阅读全文
加载中

作者的其它热门文章

打赏
0
0 收藏
分享
打赏
0 评论
0 收藏
0
分享
返回顶部
顶部
返回顶部
顶部