Hive解析Json数据

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Hive解析Json数据相关的知识,希望对你有一定的参考价值。

参考技术A 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;

Hive 解析 JSON 串的两个方向

Hive 处理 json 数据总体来说有两个方向的路走:

a.将 json 以字符串的方式整个入 Hive 表,然后通过使用 UDF 函数解析已经导入到 hive 中的数据,比如使用 LATERAL VIEW json_tuple 的方法,获取所需要的列名。

b.在导入之前将 json 拆成各个字段,导入 Hive 表的数据是已经解析过的。这将需要使用第三方的
SerDe。

以上是关于Hive解析Json数据的主要内容,如果未能解决你的问题,请参考以下文章

hive 存储,解析,处理json数据

Hive解析Json数组超全讲解

Hive解析Json数组超全讲解

hive json数据解析

Hive 解析 JSON 串的两个方向

Hive 解析 JSON 串的两个方向