hivesql:提取目标字段相关字符的对应字符

需求

SELECT  A.*
FROM ZONE A;
得:2000,8000;70271,19147;900001,0;
求:70271->19147 /900001->0

解决

思路1:键值对
-- 方法一:函数比较不通用
select str_to_map(element_str,'\073',',')['70451']
from  ZONE;
思路2:
①split(hivesql 可行,mysql不可行)
set hivevar:var='|200:330|233:235|23:24|';
select if(instr(${hivevar:var},'|230:')>0,
split(substr(substr(${hivevar:var},instr(${hivevar:var},'|230:')),length('|230:')+1),'\|')[0],'');
②较为通用,但语句比较臃肿
set hivevar:var='|200:330|233:235|23:24|';
select if(instr(${hivevar:var},'|230:')>0,
substr(substr(substr(${hivevar:var},instr(${hivevar:var},'|230:')),length('|230:')+1),
1,
instr(substr(substr(${hivevar:var},instr(${hivevar:var},'|230:')),length('|230:')+1),'|')-1
)
,'');
思路3:正则表达式
select regexp_extract(REGEXP_extract(concat('\073',a.element_str),'(\073900007,[^\073]*)',1), '(?<=,)(.*)',1),
a.element_str
from zone a	

注意事项

在目标字段前加; 防止出现匹配结果一致的情况
;13,23;1913,23
如果前面不加;查找13时容易出现多个匹配项

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值