MariaDB/MySQL 选择查询将 id 的 json 数组替换为串联值

2024-01-21

我不太熟悉数据库查询,但我想执行以下操作:在表中,我存储了一列标签 ID,例如:[1,6,8]我想回来"Music, Dance, Pop"例如在我的选择查询中。

我没有设计数据库架构,也不允许我修改它。

我想这样做的原因是这个查询的响应将直接发送到客户端进行表渲染,并且使用当前的 ORM 检索(PHP Laravel),这需要很长时间才能为每一行检索相同的相关模型。所以我想知道是否可以进行这样的查询。

我的架构看起来像这样:

posts

id | name | ... | tag_ids (JSON array) | ...

tags

id | name

我想过用JSON_REPLACE,但根本不知道如何解决这个问题。在没有代码来对结果进行后处理的情况下,这是否可以在纯 SQL 中实现?


并且我不被允许修改它

理想情况下,您可能会考虑标准化数据,这将使处理此问题变得更容易。话虽这么说,在 JSON 函数的帮助下,我们可以尝试将联接与聚合相结合:

SELECT
    p.id,
    p.name,
    GROUP_CONCAT(t.name) AS tag_names
FROM posts p
LEFT JOIN tags t
    ON JSON_SEARCH(p.tag_ids, 'one', t.id) IS NOT NULL
GROUP BY
    p.id,
    p.name;
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

MariaDB/MySQL 选择查询将 id 的 json 数组替换为串联值 的相关文章

随机推荐