MYSQL -- 根据JSON列将一行拆为多行

使用JSON_TABLE

例如表中存在 json 字段 json_filed
在这里插入图片描述
我们要实现如下效果
在这里插入图片描述
可以使用 json_table 去实现,json_table 可以将 json 字段转换为 table 去使用

SELECT json_field,j.json_single_value FROM `user`
left join 
json_table(json_field, '$[*]' columns (json_single_value int path '$')) as j on true

查询结果如下,由一行分割成多行
在这里插入图片描述

Incorrect arguments to JSON_TABLE

有些时候我们会用到子查询,如下

SELECT a.json_field,j.json_single_value FROM 
( select * from `user` where 1=1) as a
left join json_table(a.json_field, '$[*]' columns (json_single_value int path '$')) as j on true

我们需要先对目标表进行筛选,用来节省占用内存,并提高查询效率,然后再将其 json 字段转换为 table
但是当我们运行上面的 SQL 时会爆出 Incorrect arguments to JSON_TABLE 的错误。
原因是我们子查询中的 json_field 字段格式有问题,需要我们强制转换一下

SELECT a.json_field,j.json_single_value FROM 
( select * from `user` where 1=1) as a
left join json_table(CAST(a.json_field AS JSON), '$[*]' columns (json_single_value int path '$')) as j on true

猜你喜欢

转载自blog.csdn.net/qq_40096897/article/details/130288773