欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 健康 > 养生 > 如何使用HiveSQL实现2个字符串间的映射及排序

如何使用HiveSQL实现2个字符串间的映射及排序

2025/6/30 20:05:41 来源:https://blog.csdn.net/weixin_43451620/article/details/148210590  浏览:    关键词:如何使用HiveSQL实现2个字符串间的映射及排序

这里写自定义目录标题


有2个表,1个表user_class存在2个字段:class,codes,另一个表user_info有2个字段:code,name。
期望返回每个class的codes及names,codes按照正序排序,names和codes顺序保持一致?

with user_class as (select 'A' as class,'2\|1\|3' as codesunion all select 'B' as class,'2\|1' as codes
),
user_info as (select '1' as code,'TOM' as nameunion allselect '2' as code,'Jim' as nameunion allselect '3' as code,'An' as name
)
select w.class,regexp_replace(w.code,'[0-9]+_','') code,regexp_replace(w.name,'[0-9]+_','') name from (
select r.class,concat_ws(',',sort_array(collect_list(r.code))) code,concat_ws(',',sort_array(collect_list(r.name))) name
from (
select s.class,concat(lpad(s.rnt,4,'0'),'_',s.code) code,concat(lpad(s.rnt,4,'0'),'_',s.name) name
from (
select t1.class,t1.code,t2.name,row_number() over(partition by t1.class order by t1.code) rnt from (
selectt.class,s.code
from user_class t 
lateral view posexplode(split(codes,'\\|')) s as pos,code
) t1
left join
(select code,name
from user_info) t2
on t1.code = t2.code
) s
) r group by r.class
) w

实现结果如下:在这里插入图片描述

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词