Hive解析字段为Json的数据

本文介绍了HIVE中用于解析JSON格式数据的两个内置函数:get_json_object和json_tuple。get_json_object函数可以提取指定路径的单个数据项,而json_tuple函数则允许一次性提取多个字段,提高处理效率。

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

HIVE直接读入json的函数有两个:

(1)get_json_object(string json_string, string path)

返回值: string

说明:解析json的字符串json_string,返回path指定的内容。如果输入的json字符串无效,那么返回NULL。

举例:

hive> select get_json_object(‘{“store”:{“fruit”:[{"weight":8,"type":"apple"},{"weight":9,"type":"pear"}], “bicycle”:{“price”:19.95,”color”:”red”}}, “email”:”amy@only_for_json_udf_test.net”, “owner”:”amy” } ‘,’$.owner’) from dual;

结果:amy

这个函数每次只能返回一个数据项。

(2)json_tuple(jsonStr, k1, k2, ...)

参数为一组键k1,k2……和JSON字符串,返回值的元组。该方法比 get_json_object 高效,因为可以在一次调用中输入多个键

select a.timestamp, b.*
from log a lateral view json_tuple(a.appevent, 'eventid', 'eventname') b as f1, f2;

处理数据样例:

{
	"GPS_LAT": 39.8965125,
	"GPS_LONG": 116.3493225,
	"GPS_SPEED": 20.9993625,
	"GPS_STATE": "A",
	"GPS_TIME": "2014-01-02 00:00:16",
	"IMEI": "508597",
	"after_oxygen_sensor": 132,
	"air_condion_state": 3,
	"bdoneNo_after_mileage": 0,
	"bdoneNo_zero_mileage": 8044,
	"db_speed": 22,
	"direction_angle": 358.2585,
	"front_oxygen_sensor": 64,
	"instant_fuel": 233,
	"speed": 1210,
	"torque": 33,
	"total_fuel": 0
}


处理HIVE语句:

create table 2014jrtest as select json_tuple(line,'GPS_LAT','GPS_LONG','GPS_SPEED','GPS_STATE','GPS_TIME','IMEI','after_oxygen_sensor','air_condion_state','bdoneNo_after_mileage','bdoneNo_zero_mileage','db_speed','direction_angle','front_oxygen_sensor','instant_fuel','speed','torque','total_fuel') from 2014test;



作者:石晓文的学习日记
链接:https://www.jianshu.com/p/8a868d2ac307
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值