首先在百度搜索,json格式解析,将这段话变个格式看起来舒服。
然后,通过通过嵌套使用json函数解决。大概就是将内层的json字段当作一个整体,然后先将这个外层作为解析。在通过子查询使用方法,在外套一层json查询,将当作整体的界面在json解析就出来了;
简单举例:
数据内容:
{"name":"abc","age":"18","home":{"sheng":"neomenggu"}}
1.可以解析多个字段:
json_tuple(字段,“m1”,“m2”) as (别名1,别名2)
注意:
1.可以不起别名。
2.只要起别名,就都写上。
3.这个不可以嵌套使用
1.简单举例:![在这里插入图片描述](https://img-blog.csdnimg.cn/6ab475527bd248ac90a2bd316e01f28a.png)
这个data是我创建的一个表的字段名字。表中只有这一个结构
select
json_tuple(data,"name","age") as(name,age)
from test_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;