hive函数str_to_map

str_to_map函数用于将使用分隔符拆分的文本转化为Hive中的键值对映射。该函数接受两个分隔符,第一个用于分割键值对,第二个用于分割键和值。示例中展示了如何处理KV格式的数据,通过regexp_replace清洗数据,以及如何使用concat创建map字段。此外,还说明了如何直接访问并使用map中的字段。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

str_to_map(字符串参数, 分隔符1, 分隔符2)

使用两个分隔符将文本拆分为键值对。

分隔符1将文本分成K-V对,分隔符2分割每个K-V对。对于分隔符1默认分隔符是 ',',对于分隔符2默认分隔符是 '='

 

例子:

1. 创建map字段

1

2

3

4

5

6

DROP TABLE IF EXISTS tmp.tmp_str_to_map;

CREATE TABLE IF NOT EXISTS tmp.tmp_str_to_map

(

ocolumn string comment '原始字段',

rcolumn map<string,string> comment 'map字段'

);

  

--------------------------------------------------------------------

如果数据很想kv 直接清洗下数据转成map:

str_to_map(regexp_replace(params,'[\"|\{|\}]',''),'&',':') as params,   ---数据是用& 分割,kv以:分割

--------------------------------------------------------------------


2. concat + str_to_map函数

用concat + & 取表字段拼接成map类型

1

2

3

4

5

6

7

insert overwrite table tmp.tmp_str_to_map

SELECT

concat('&crowd:', m0.id,'&clicker:',m0.dui_leader,'&sen:',m0.application_type) ocolumn,

str_to_map(concat('column1:', m0.id,'&column2:',m0.dui_leader,'&column3:',m0.application_type), '&'':') rcolumn

FROM tmp.tmp_adhoc_detail_20180927 m0

limit 1

;

  

3. 取用map里的字段,用[""]即可

1

2

3

4

select

rcolumn,

rcolumn["column1"] column1

from tmp.tmp_str_to_map;

 

4. 也可以直接转换取用,而不需要存储字段

1

2

3

4

SELECT

  m0.id column1,

  str_to_map(concat('column1:', m0.id,'&column2:',m0.dui_leader,'&column3:',m0.application_type), '&'':')["column1"] column1_1

from tmp.tmp_adhoc_detail_20180927 m0 <br>limit 1

  

5. 结果:

rcolumn

1

<span style="font-size: 14px"><strong>column1</strong></span>

{"column1":"1","column2":"李某某","column3":"创新班"}1
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值