005.hive分組求中位數--sort_array(collect_list(),insert overwrite table --- 實現字段update操作


    select 
     occur_period 
     ,arr_1
     ,case when size(arr_1)%2=1  then arr_1[cast((size(arr_1)-1)/2 as int )]
       else (arr_1[cast(size(arr_1)/2 as int) ]+arr_1[cast(( size(arr_1)/2-1 )as int)])/2 
       end as zws_1
     ,case when size(arr_2)%2=1  then arr_2[cast((size(arr_2)-1)/2 as int )]
       else (arr_2[cast(size(arr_2)/2 as int) ]+arr_2[cast(( size(arr_2)/2-1 )as int)])/2 
       end as zws_2
    from 
    (    
     select 
     occur_period 
     , sort_array(collect_list(num_jdz_1)) as arr_1
     , sort_array(collect_list(num_jdz_2)) as arr_2
     from 
     qhtest.num_zws_update_test
     group by occur_period
    )a

 

自帶的中位數函數是去重求中位數

小數 percentile_approx
 
select percentile_approx( i_de_js, 0.5) from qhtest.test_table_zws;  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM