Hive中解析Json字段、json日志分析所用到的嵌套json解析

首先在百度搜索,json格式解析,将这段话变个格式看起来舒服。
然后,通过通过嵌套使用json函数解决。大概就是将内层的json字段当作一个整体,然后先将这个外层作为解析。在通过子查询使用方法,在外套一层json查询,将当作整体的界面在json解析就出来了;
简单举例:
数据内容:

{"name":"abc","age":"18","home":{"sheng":"neomenggu"}}

1.可以解析多个字段:

json_tuple(字段,“m1”,“m2”) as (别名1,别名2)
注意:
1.可以不起别名。
2.只要起别名,就都写上。
3.这个不可以嵌套使用

1.简单举例:Hive中解析Json字段、json日志分析所用到的嵌套json解析_第1张图片

这个data是我创建的一个表的字段名字。表中只有这一个结构

select 
json_tuple(data,"name","age") as(name,age)
from test_2;

结果:
Hive中解析Json字段、json日志分析所用到的嵌套json解析_第2张图片

2 解析单个字段:(二重嵌套)

注意:最里面的字段要写道外部,从左向右进行做,如下图,home中还有json格式数据,那么在嵌套解析。用home字段名字,解析中间的数据;这样旧解析出来了

select name,age,home,
get_json_object(t1.home,'$.sheng') sheng
from(
select get_json_object(data,'$.name') name,
get_json_object(data,'$.age') age,
get_json_object(data,'$.home') home
from test2) t1;

Hive中解析Json字段、json日志分析所用到的嵌套json解析_第3张图片

你可能感兴趣的:(Hive,hive,json)