最终结果:
数据库表
A表:
B表:
操作步骤
主要关键字:FIND_IN_SET、GROUP_CONCAT、LEFT JOIN、GROUP BY
第一步:left join 连接AB表并通过 find_in_set 关联其ID
select us.id,us.name,us.hobbyId,hb.name hobby from hobby hb left join user us on find_in_set(hb.id,us.hobbyId)
结果:name 字段名称很多重复,做去重处理
第二步:去重 GROUP BY
select us.id,us.name,us.hobbyId,hb.name hobby from hobby hb left join user us on find_in_set(hb.id,us.hobbyId) GROUP BY(us.name)
结果:这是名称已经分组了,但是 hobby 与 hobbyId 对不上
第三步:使用 GROUP_CONCAT
select us.id,us.name,us.hobbyId,GROUP_CONCAT(hb.name) hobby from hobby hb left join user us on find_in_set(hb.id,us.hobbyId) GROUP BY(us.name) ORDER BY us.id
原文地址:https://www.cnblogs.com/zhcblog-20181026/p/11261665.html
时间: 2024-10-10 21:20:07