首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用left join查询和匹配MySQL中的JSON字段

使用left join查询和匹配MySQL中的JSON字段
EN

Stack Overflow用户
提问于 2020-11-09 18:13:44
回答 1查看 247关注 0票数 0

表A,字段: pay_type_fk,类型:json,示例数据: 1,2,4表B,字段: id类型: bigint示例数据:主键

我使用的SQL:

代码语言:javascript
运行
复制
SELECT
    pay_payment_type.id,
    pay_payment_type.pay_name,
    pay_payment_type.configuration,
    pay_payment_type.pay_function_name,
    GROUP_CONCAT( pay_type.MODE ) 
FROM
    pay_payment_type
    LEFT JOIN pay_type ON pay_type.id = CAST( JSON_EXTRACT( pay_payment_type.pay_type_fk, '$[0]' ) AS UNSIGNED ) 
GROUP BY
    pay_payment_type.id

对于类型表中的第一条记录,只有pay可以为found_,我想我们可以用group_ CONCAT来查询所有这些记录

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-11-09 18:17:03

如果我没听错,你可以在JSON_CONTAINS()上使用join

代码语言:javascript
运行
复制
select
    ppt.id,
    ppt.pay_name,
    ppt.configuration,
    ppt.pay_function_name,
    group_concat(pt.mode) as pay_type_modes 
from pay_payment_type ppt
left join pay_type pt on json_contains(ppt.pay_type_fk, cast(pt.id as char))
group by ppt.id

也就是说,一个更好的选择是修复你的设计。您应该使用单独的桥接表来表示这种多对多关系,而不是使用JSON数组来存储多个依赖键,每个值都在单独的行中。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64749618

复制
相关文章

相似问题

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