【Hive】json解析函数get_json_object

这篇博文主要分享在Hive里面使用get_json_object函数来解析json格式数据的具体用法。

在数据表test中有一列jsonData,其数据如下:

jsonData = '{
	"ID":121,
	"message":{
		"name":"Asher",
		"location":[{"county":"浦东","city":"上海"},
					{"county":"西直门","city":"北京"}]
	}	
}'

--PS:jsonData列数据为字符串格式,外面是**单引号**,里面是**双引号**(这个不能弄错了,否则不对)

1.提取jsonData第一层数据ID

select get_json_object(jsonData,'$.ID') from test

--输出
>121

2.提取jsonData第二层数据name

select get_json_object(jsonData,'$.message.name') from test

--输出
>Asher

3.提取jsonData第二层数据location的第一项

select get_json_object(jsonData,'$.message.location[0]') from test

--输出
>{"county":"浦东","city":"上海"}

4.提取jsonData第二层数据location的第一项的city

select get_json_object(jsonData,'$.message.location[0].city') from test

--输出
>上海

5.提取jsonData第三层数据city

select get_json_object(jsonData,'$.message.location.city') from test

--输出
>["上海","北京"]

码字不易,喜欢请点赞,谢谢!!!

  • 30
    点赞
  • 146
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值