1对n关联表的联接查询

1对n关联表的联接查询

背景

测试若依框架易用性,尝试写一个关联表demo

问题描述

有用户表user(sys_id,name,sex,department)和部门表dept(id,dept_name,dept_code)。

其中,用户表的department使用逗号分隔的若干部门id,我想要的实际效果是,一个用户姓名和若干部门名称放在一行展示。

分析

预想的是将department字段分割后,逐一与dept表匹配,搜到了substring_index函数,感觉挺麻烦。

偶见别人写的一句...WHERE CONCAT(',', code, ',') LIKE '%123%' ...

受此启发,将department字段和dept的id的首尾都拼接上逗号,使用like+%进行匹配。

department加逗号理由:防止首末元素无法匹配;
id加逗号理由:防止前后缀多余字符干扰结果。

这里可能有点令人费解,like后的字符串,可以理解为是关键词,like前的字符串,可以理解为是数据源,like语句可以理解为,数据源中匹配关键词

解决完匹配问题以后,对sys_id分组,使用max函数获取name等字段,使用GROUP_CONCAT函数拼接部门名称(默认逗号分隔)。

解决方案

样例如下:

select MAX(name)                     AS name,
       MAX(sex)                      as sex,
       MAX(department)               as department,
       GROUP_CONCAT(department_name) as department_name
from user
         left join dept on CONCAT(',', department, ',') like CONCAT('%,', id, ',%')
where user_type = '0'
group by user_id

声明:本文使用八爪鱼rpa工具从gitee自动搬运本人原创(或摘录,会备注出处)博客,如版式错乱请评论私信,如情况紧急或久未回复请致邮 xkm.0jiejie0@qq.com 并备注原委;引用本人笔记的链接正常情况下均可访问,如打不开请查看该链接末尾的笔记标题(右击链接文本,点击 复制链接地址,在文本编辑工具粘贴查看,也可在搜索框粘贴后直接编辑然后搜索),在本人博客手动搜索该标题即可;如遇任何问题,或有更佳方案,欢迎与我沟通!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值