Hive解析json格式字段

新建hive表

create external table asmp.json_test(
id string,
info string
)
row format delimited fields terminated by '\t' lines terminated by '\n'
location 'hdfs://nameservice1/user/asmp/json_test'

插入数据

1	[{"name":"Tom","city":"Beijing"},{"name":"Jack", "city":"Shanghai"},{"name":"Bill", "city":"Tianjin"}]
2	[{"name":"David", "city":"Beijing"},{"name":"Jack", "city":"Shanghai"},{"name":"Bill", "city":"Tianjin"}]

处理数据1:

SELECT t.id,get_json_object(concat('{',names,'}'),'$.name') as passengername
FROM asmp.json_test t 
LATERAL VIEW explode(split(regexp_replace(regexp_replace(t.info,'\\[\\{',''),'}]',''),'},\\{')) names as names 

在这里插入图片描述

处理数据2:

select a.id,count(a.passengername) nums from
(
SELECT t.id,get_json_object(concat('{',names,'}'),'$.name') as passengername
FROM asmp.json_test t 
LATERAL VIEW explode(split(regexp_replace(regexp_replace(t.info,'\\[\\{',''),'}]',''),'},\\{')) names as names 
) a
group by a.id 

在这里插入图片描述
使用到的函数:

#regexp_replace(string initial_string, string pattern, string replacement) 根据正则表达式处理文本格式
第一个参数为字段,第二个参数为要替换的文本格式,第三个参数为替换后的目标格式,第二第三个参数均使用正则表达。

#split(string str, string pat) 将字符串分割
第一个参数为操作的字符串,第二个参数为分割符。

#lateral view explode()
行转列,将一个字段内的内容拆成多行

CONCAT()
将多个字符串合并为一个

#get_jason_object(column, "$.parameter") 解析json数据
第一个参数是选择的字段,第二个参数是json数据中选择的参数

Hive,我们可以使用一些内置的函数来解析JSON数据。其最常用的函数是get_json_object和json_tuple。get_json_object函数用于提取JSON对象的特定字段值,而json_tuple函数则可以一次解析多个JSON字段。但是这两个函数都无法处理JSON数组的情况。对于处理JSON数组,我们可以使用自定义的serde(序列化/反序列化)来解析。一个常用的serde是json-serde,它可以帮助Hive解析和处理JSON数据。你需要将json-serde.jar添加到Hive的classpath,并创建一个外部表来指定使用该serde。然后可以使用Hive的查询语句来解析JSON数组的数据。例如,你可以使用add jar命令将json-serde.jar添加到Hive,并创建一个表来解析JSON数组数据。具体的使用方法可以参考相关文档或指南。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [学会Hive解析Json数组](https://blog.csdn.net/ytp552200ytp/article/details/125277965)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [hive解析json格式数据所需jar包](https://download.csdn.net/download/ls386239766/8662797)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值