MYSQL -- 根据JSON列将一行拆为多行
json
适用于现代 C++ 的 JSON。
项目地址:https://gitcode.com/gh_mirrors/js/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
GitHub 加速计划 / js / json
41.72 K
6.61 K
下载
适用于现代 C++ 的 JSON。
最近提交(Master分支:23 天前 )
960b763e
3 个月前
8c391e04
6 个月前
更多推荐
已为社区贡献4条内容
所有评论(0)