HIVE分組排序問題

 

答案:spa

hive> select *,row_number() over (partition by product_no order by start_time desc) from table1;3d

 

 

知識點:code

一、row_number
  1. hive (test)> select *, row_number() over (partition by sub order by score) as od from t; 
 
二、rank
  1. hive (test)> select *, rank() over (partition by sub order by score) as od from t; 
 
三、dense_ran
  1. hive (test)> select *, dense_rank() over (partition by sub order by score desc) from t;
 
業務實例:
統計每一個學科的前三名
  1. select * from (select *, row_number() over (partition by sub order by score desc) as od from t ) t where od<=3;
語文成績是80分的排名是多少
  1. hive (test)> select od from (select *, row_number() over (partition by sub order by score desc) as od from t )t where sub=‘chinese‘ and score=80;
分頁查詢
  1. hive (test)> select * from (select *, row_number() over () as rn from t) t1 where rn between 1 and 5;
相關文章
相關標籤/搜索