首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >将多个COLUMN_JSON结果作为JSON数组返回

将多个COLUMN_JSON结果作为JSON数组返回
EN

Stack Overflow用户
提问于 2016-10-09 11:54:49
回答 1查看 1.4K关注 0票数 2

我将数据存储在MariaDB中的标准表中,但希望将相关表中的记录作为JSON字符串返回。

我打算做的是有一个函数,在其中我可以传入exerciseId,并且函数返回所有相关exerciseMuscle记录的JSON字符串,这意味着存储的proc返回的每个exercise记录也可以包含来自子表的嵌套数据。

我已经能够使用COLUMN_JSONCOLUMN_CREATE创建JSON记录,但只能将其作为一组单独的记录返回,而不是作为需要的JSON值数组返回。我使用的SQL是:

代码语言:javascript
运行
复制
select
    e.id, 
    CONVERT(COLUMN_JSON(COLUMN_CREATE(
        'role', em.muscleRoleName, 
        'muscle', em.muscleName
    )) USING utf8) as musclesJson
from
    exercise e
    inner join exerciseMuscle em
            on e.id = em.exerciseId
where
    e.id = 96;

这将返回:

代码语言:javascript
运行
复制
| id | musclesJson 
| 96 | {"role":"main","muscle":"biceps"}
| 96 | {"role":"secondary","muscle":"shoulders"}

我想要的是:

代码语言:javascript
运行
复制
| id | musclesJson 
| 96 | [{"role":"main","muscle":"biceps"},{"role":"secondary","muscle":"shoulders"}]

是否可以在一行中返回多个结果,而不必遍历结果并手动构建?如果我向SQL添加一个group by,那么JSON只包含第一个记录。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-10-09 12:36:58

原来我需要的是GROUP_CONCAT,并指定一个逗号作为分隔符。因此,将我的SQL更改为:

代码语言:javascript
运行
复制
select
    e.id, 
    CONVERT(
        GROUP_CONCAT(
            COLUMN_JSON(
                COLUMN_CREATE(
                    'role', em.muscleRoleName, 
                    'muscle', em.muscleName
                )
            )
            SEPARATOR ','
        ) USING utf8) as muscles 
from
    exercise e
    inner join exerciseMuscle em
            on e.id = em.exerciseId
where
    e.id = 96;

返回:

代码语言:javascript
运行
复制
| id | musclesJson 
| 96 | {"role":"main","muscle":"biceps"},{"role":"secondary","muscle":"shoulders"}
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39943309

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档